# WН

## **CH567 Datasheet**

## Overview

CH567 is a high-performance 32-bit RISC reduced instruction set microcontroller, built-in 192KB FLASH memory, 32KB SRAM and 32KB DataFlash. The chip is integrated with two sets of independent high-speed USB2.0 master/slave controller, 4 groups of SD controllers, encryption algorithm modules, 4 groups of UART interfaces, 7 groups of PWMs, 3 groups of timers and other peripheral resources, which can be widely used for various embedded applications.

## Function

- Core:
  - 32-bit RISC reduced instruction set core
  - Highest frequency of 120MHz
- Memory:

-192KB-byte program memory, support write protection

- 32KB-byte SRAM
- 32KB-byte DataFlash
- Double USB2.0 high-speed receiver-transmitter (built-in PHY):
  - High-speed Host / Device mode
  - Support control/batch/interrupt/synchronous transmission
  - Support double buffer PINT-PONG mechanism
  - Support DMA
- 4 groups of independent SD controllers:
  - Support single-wire, 4-wire, 8-wire communication mode

- Support SD/TF card, SDIO card and eMMC card, etc.

- Built-in FIFO
- Support AES and SM4 Algorithms
- Provide 8 encryption and decryption modes
- Support DMA
- Timer:
  - 3 sets of 26-bit timers

 Support functions of signal width sample / edge capture, PWM adjustable output and count
 TMR1 and TMR2 support DMA

• Universal asynchronous receiver/transmitter (UART):

- 4 groups of independent UARTs, compatible

## with 16C550

- The highest baud rate is 6Mbps
- Built-in FIFO, multiple trigger levels
- PWMX:
  - Expand 4 sets of PWM output
  - Adjustable duty cycle
- SPI:

- 2 sets of SPI interfaces: one supports Master and Slave mode, and the other supports only Master mode

- Built-in FIFO
- SPI0 supports DMA
- LED screen interface:
  - Support 1/2/4-channel data lines
  - Built-in FIFO, support double buffer
  - Support DMA
- Active parallel port:
  - 8-bit data, 15-bit address bus
  - Adjustable timing sequence
- Low power:
  - Sleep mode
  - Support some GPIOs or USB signal wake up
  - General-purpose I/O port:
  - 30 GPIOs
  - 8 pins can be set level or edge interrupt
  - Some pins have multiplexing and mapping functions
- ID Number of chip:
- Unique 64bit ID identification number
- Power supply:
  - 3.0---3.6V (3.3V±10%)
- Package: LQFP48

## Application

Security storage, home security, USB-related applications, monitoring, alarm systems, printers, scanners and other application control.

## **Chapter 1 Pin Information**

## **1.1 Pin Configuration**



Figure 2-1 LQFP48 Package Pin Arrangement

## **1.2 Pin Description**

| Pin<br>No. | Pin<br>Name | Pin<br>Type | Main Function (after reset)/<br>Multiplexing Function and<br>Mapping | Function Description                                                                                                                                                                                                                                      |
|------------|-------------|-------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | PA1         | I/O         | PA1<br>/MOSI1/LED1/CMD2/A1                                           | <ul><li>PA1: General purpose bidirectional digital I/O pin.</li><li>MOSI1: SPI1 serial data pin, host output.</li><li>LED1: LED serial data line 1.</li><li>CMD2: SD2 controller command signal line.</li><li>A1: Parallel port address line 1.</li></ul> |
| 2          | PA0         | I/O         | PA0<br>/SCK1/LED0/CMD1/A0                                            | PA0: General purpose bidirectional digital I/O pin.<br>SCK1: SPI1 serial clock pin, host clock output.<br>LED0: LED serial data line 0.                                                                                                                   |

|     |        |       |                         | CMD1: SD1 controller command signal line.                     |
|-----|--------|-------|-------------------------|---------------------------------------------------------------|
|     |        |       |                         | A0: Parallel port address.                                    |
|     |        |       |                         | 1 set of 3.3V power supplies for peripherals, requires        |
| 3   | V33IO1 | Р     | V33IO1                  | an external 0.1uF capacitor.                                  |
|     |        |       |                         | PB7: General purpose bidirectional digital I/O pin.           |
|     |        |       | PB7                     | TXD0: UART0 serial data output.                               |
| 4   | PB7    | I/O   | /TXD0/SD33/D7           | SD33: SD3 controller data line 3.                             |
|     |        |       | /1200/5033/07           |                                                               |
|     |        |       |                         | D7: Parallel data line 7.                                     |
|     |        |       |                         | PB6: General purpose bidirectional digital I/O pin.           |
| ~   | DD (   | T/O   | PB6                     | RTS: MODEM output signal of UART0; request to                 |
| 5   | PB6    | I/O   | /RTS/SD32/D6            | send.                                                         |
|     |        |       |                         | SD32: SD3 controller data line 2.                             |
|     |        |       |                         | D6: Parallel data line 6.                                     |
|     |        |       |                         | PB5: General purpose bidirectional digital I/O pin.           |
|     |        |       | PB5                     | DTR: MODEM output signal of UART0; data                       |
| 6   | PB5    | I/O   | /DTR/SD31/D5            | terminal is ready.                                            |
|     |        |       |                         | SD31: SD3 controller data line 1.                             |
|     |        |       |                         | D5: Parallel data line 5.                                     |
|     |        |       |                         | PB4: General purpose bidirectional digital I/O pin.           |
|     |        |       | PB4                     | SD30: SD3 controller data line 0.                             |
| 7   | PB4    | I/O   | /SD30/D4/RXD0/INT6      | D4: Parallel data line 4.                                     |
|     |        |       | /SD30/D4/KAD0/IN10      | RXD0: UART0 serial data input.                                |
|     |        |       |                         | INT6: IO interrupt 6.                                         |
|     |        |       |                         | PB3: General purpose bidirectional digital I/O pin.           |
|     |        |       | DD2                     | SD23: SD2 controller data line 3.                             |
| 8   | PB3    | I/O   | PB3                     | D3: Parallel data line 3.                                     |
|     |        |       | /SD23/D3/DCD            | DCD: MODEM input signal of UART0; carrier                     |
|     |        |       |                         | detection.                                                    |
|     |        |       |                         | PB2: General purpose bidirectional digital I/O pin.           |
|     |        |       |                         | PWM5 : PWM5 function mapping.                                 |
|     |        | - 1 - | PB2                     | SD22: SD2 controller data line 2.                             |
| 9   | PB2    | I/O   | /PWM5 /SD22/D2/CAP1 /RI |                                                               |
|     |        |       |                         | CAP1 : CAP1 function mapping.                                 |
|     |        |       |                         | RI: MODEM input signal of UART0; ring indicator.              |
|     |        |       |                         | PB1: General purpose bidirectional digital I/O pin.           |
|     |        |       |                         | SD21: SD2 controller data line 1.                             |
| 10  | PB1    | I/O   | PB1                     | D1: Parallel data line 1.                                     |
|     |        | ~ ~   | /SD21/D1/DSR            | DTR: MODEM input signal of UART0; data device                 |
|     |        |       |                         | is ready.                                                     |
|     |        |       |                         | PB1: General purpose bidirectional digital I/O pin.           |
|     |        |       | PB0                     | SD20: SD2 controller data line 0.                             |
| 11  | PB0    | I/O   | /SD20/D0/CTS            | D0: Parallel data line 0.                                     |
|     |        |       | 15020/00/015            | CTS: MODEM input signal of UART0; clear to send.              |
|     |        |       |                         | It is required to be connected with a $12K\Omega$ resistor to |
| 12  | RUSB0  | I/O   | RUSB0                   |                                                               |
| 1.2 | LIDDO  | HOD   |                         | ground for USB0-PHY.                                          |
| 13  | UDP0   | USB   | UDP0(UD0+)              | USB0 bus D+ data line.                                        |
| 14  | UDM0   | USB   | UDM0(UD0-)              | USB0 bus D- data line.                                        |
| 15  | V33USB | P     | V33USB                  | USB0 peripheral power supply.                                 |
| 16  | XO     | I/O   | XO                      | Crystal oscillator inverted output                            |

Relevant information can be downloaded from the website: <u>www.wch.cn</u>

2

| 17 | XI     | Ι    | XI                   | Crystal oscillator input                                                                   |
|----|--------|------|----------------------|--------------------------------------------------------------------------------------------|
| 18 | RUSB1  | I/O  | RUSB1                | It is required to be connected with a $12K\Omega$ resistor to                              |
| 10 | LUDD1  | LICD |                      | ground for USB1-PHY.                                                                       |
| 19 | UDP1   | USB  | UDP1(UD1+)           | USB1 bus D+ data line.                                                                     |
| 20 | UDM1   | USB  | UDM1(UD1-)           | USB1 bus D- data line.                                                                     |
| 21 | V33IO3 | Р    | V33IO3               | 3 sets of 3.3V power supply for USB1 and peripheral, requires an external 0.1uF capacitor. |
| 22 | GND    | Р    | GND                  | Ground: common ground, 0V reference point.                                                 |
|    |        |      |                      | Core power supply, must be connected to VCORE                                              |
| 23 | VCORE  | Р    | VCORE                | and an external 0.1uF capacitor is required.                                               |
|    |        |      |                      | PB11: General purpose bidirectional digital I/O pin.                                       |
| 24 | PB11   | I/O  | PB11                 | PWM6_: PWM6 function mapping.                                                              |
| 24 | PDII   | 1/0  | /PWM6_/A14/CAP2_     | A14: Parallel port address line 14.                                                        |
|    |        |      |                      | CAP2_: CAP2 function mapping.                                                              |
| 25 | PB12   | I/O  | PB12                 | PB12: General purpose bidirectional digital I/O pin.                                       |
| 23 | PD12   | 1/0  | /A12                 | A12: Parallel port address line 12.                                                        |
| 26 | PB13   | I/O  | PB13                 | PB13: General purpose bidirectional digital I/O pin.                                       |
| 20 | PDIS   | 1/0  | /A13                 | A13: Parallel port address line 13.                                                        |
|    |        |      | PB8                  | PB9: General purpose bidirectional digital I/O pin.                                        |
| 27 | PB8    | I/O  | /RD#/RXD1            | RD#: Parallel port read control line.                                                      |
|    |        |      | /KD#/KADI_           | RXD1_: RXD pin mapping of UART1.                                                           |
|    |        |      | PB9                  | PB9: General purpose bidirectional digital I/O pin.                                        |
| 28 | PB9    | I/O  | /TXD1 /WR#           | TXD1_: TXD pin mapping of UART1.                                                           |
|    |        |      |                      | WR#: Parallel port write control line.                                                     |
|    |        |      |                      | PB10: General purpose bidirectional digital I/O pin.                                       |
| 29 | PB10   | I/O  | PB10                 | DBGIO: Data input and output port of simulation and                                        |
| 2) | 1010   | шO   | /DBGIO/INT7          | debugging interface.                                                                       |
|    |        |      |                      | INT7: IO interrupt 7.                                                                      |
|    |        |      |                      | RST#: External reset input pin, active low, built-in                                       |
| 30 | RST#   | Ι    | RST#                 | pull-up resistor.                                                                          |
| 50 | 10011  | 1    | /DBGCK               | DBGCK: Clock input port of simulation and                                                  |
|    |        |      |                      | debugging interface.                                                                       |
|    |        |      |                      | PA3: General purpose bidirectional digital I/O pin.                                        |
|    |        |      | PA3                  | PWM4: Pulse width modulation output channel 4.                                             |
| 31 | PA3    | I/O  | /PWM4/LED3/A3/CAP0   | LED3: LED serial data line 3.                                                              |
|    |        |      | /INT0                | A3: Parallel port address line 3.                                                          |
|    |        |      |                      | CAP0: Timer0 capture input pin.                                                            |
|    |        |      |                      | INTO: IO interrupt 0.                                                                      |
|    |        |      |                      | PA4: General purpose bidirectional digital I/O pin.                                        |
|    |        |      | PA4                  | PWM0: Pulse width modulation output channel 0.                                             |
| 32 | PA4    | I/O  | /PWM0/LEDC/A4/RXD3   | LEDC: LED serial data line.                                                                |
|    |        |      | /INT1                | A4: Parallel port address line 4.                                                          |
|    |        |      |                      | RXD3: UART3 serial data input.                                                             |
|    |        |      |                      | INT1: IO interrupt 1.                                                                      |
|    |        |      | PA5                  | PA5: General purpose bidirectional digital I/O pin.                                        |
| 33 | PA5    | I/O  | PA5<br>/TXD3/PWM1/A5 | TXD3: UART3 serial data output.                                                            |
|    |        |      | /IADJ/FWWWIVII/AJ    | PWM1: Pulse width modulation output channel 1.<br>A4: Parallel port address line 5.        |
| 34 | PA6    | I/O  | PA6                  | PA6: General purpose bidirectional digital I/O pin.                                        |
| 34 | rA0    | I/U  | rAu                  | 1 Ao. Ocherai purpose ordirectional digital I/O pln.                                       |

|    |                |            | /SDCK/A6/RXD2/INT2             | SDCK: SD controller clock line output.                                                    |
|----|----------------|------------|--------------------------------|-------------------------------------------------------------------------------------------|
|    |                |            |                                | A6: Parallel port address line 6.                                                         |
|    |                |            |                                | RXD2: UART2 serial data input.                                                            |
|    |                |            |                                | INT2: IO interrupt 2.                                                                     |
|    |                |            |                                | PA7: General purpose bidirectional digital I/O pin.                                       |
|    |                |            | PA7                            | TXD2: UART2 serial data output.                                                           |
| 35 | PA7            | I/O        | /TXD2/CMD0/A7                  | CMD0: SD0 controller command signal line.                                                 |
|    |                |            |                                | A7: Parallel port address line 7.                                                         |
|    |                |            |                                | PA8: General purpose bidirectional digital I/O pin.                                       |
|    |                |            |                                | PWM2: Pulse width modulation output channel 2.                                            |
| 36 | PA8            | I/O        | PA8                            | SDOO: SD0 controller data line 0.                                                         |
| 50 | 1710           | цО         | /PWM2/SD00/A8/RXD1             | A8: Parallel port address line 8.                                                         |
|    |                |            |                                | RXD1: UART1 serial data input.                                                            |
|    |                |            |                                |                                                                                           |
|    |                |            |                                | PA10: General purpose bidirectional digital I/O pin.                                      |
|    |                |            | PA10                           | PWM5: Pulse width modulation output channel 5.                                            |
| 37 | PA10           | I/O        | /PWM5/SD02/A10/CAP1            | SDO2: SD0 controller data line 2.                                                         |
|    |                |            | /INT3                          | A10: Parallel port address line 10.                                                       |
|    |                |            |                                | CAP1: Timer 1 capture input pin.                                                          |
|    |                |            |                                | INT3: IO interrupt 3.                                                                     |
|    |                |            |                                | PA11: General purpose bidirectional digital I/O pin.                                      |
|    |                |            | PA11                           | PWM6: Pulse width modulation output channel 6.                                            |
| 38 | PA11           | I/O        | /PWM6/SD03/A11/CAP2            | SD03: SD0 controller data line 3.                                                         |
| 50 | 1711           | ШО         | /I WIND/SD05/AII/CAI2<br>/INT4 | A11: Parallel port address line 11.                                                       |
|    |                |            | /11/14                         | CAP2: Timer2 capture input pin.                                                           |
|    |                |            |                                | INT4: IO interrupt 4.                                                                     |
| 20 | <b>W22IO2</b>  | р          | V22102                         | 2 sets of 3.3V power supplies for peripherals,                                            |
| 39 | V33IO2         | Р          | V33IO2                         | requires an external 0.1uF capacitor.                                                     |
|    |                |            |                                | PA9: General purpose bidirectional digital I/O pin.                                       |
|    |                |            | 210                            | TXD1: UART1 serial data output.                                                           |
| 40 | PA9            | I/O        | PA9                            | PWM3: Pulse width modulation output channel 3.                                            |
|    |                |            | TXD1/PWM3/SD01/A9              | SD01: SD0 controller data line 1.                                                         |
|    |                |            |                                | A9: Parallel port address line 9.                                                         |
|    |                |            |                                | Power supply voltage regulator input 3.3V power,                                          |
| 41 | V33REG         | Р          | V33REG                         | requires an external 0.1uF capacitor.                                                     |
| 42 | GND            | Р          | GND                            | Ground: common ground, 0V reference point.                                                |
|    | GILD           | -          | 0112                           | Core power supply output, and an external 3.3uF or                                        |
| 43 | VCORE          | Р          | VCORE                          | 10uF capacitor is required.                                                               |
|    |                |            |                                | PA15: General purpose bidirectional digital I/O pin.                                      |
|    |                |            | PA15                           | MIOS0: SPI0 serial data pin, host input/slave output.                                     |
| 44 | PA15           | I/O        | /MISO0/SD13/RXD0               | SD13: SD1 controller data line 3.                                                         |
|    |                |            | /1011500/5D15/KADU_            |                                                                                           |
|    |                |            |                                | RXD0_: RXD pin mapping of UART0.                                                          |
|    |                |            | DA 14                          | PA14: General purpose bidirectional digital I/O pin.                                      |
| 45 | PA14           | I/O        | PA14                           | MOSI0: SPI0 serial data pin, host output/slave input.                                     |
|    |                |            | /MOSI0/TXD0_/SD12              | TXD0_: TXD pin mapping of UART0.                                                          |
|    |                |            |                                | SD12: SD1 controller data line 2.                                                         |
|    |                |            | PA13                           | PA13: General purpose bidirectional digital I/O pin.                                      |
|    | <b>D</b> 1 1 2 |            |                                | SCK0: SPIO correl clock nin best output/clove input                                       |
| 46 | PA13           | I/O        | /SCK0/SD11                     | SCK0: SPI0 serial clock pin, host output/slave input.                                     |
| 46 | PA13<br>PA12   | I/O<br>I/O | /SCK0/SD11<br>PA12             | SD11: SD1 controller data line 1.<br>PA12: General purpose bidirectional digital I/O pin. |

Relevant information can be downloaded from the website: <u>www.wch.cn</u>

4

|    |      |     | /SD10/SCS/INT5                               | SD10: SD1 controller data line 0.                    |  |
|----|------|-----|----------------------------------------------|------------------------------------------------------|--|
|    |      |     | SCS: Chip selection input pin of SPI0 slave. |                                                      |  |
|    |      |     |                                              | INT5: IO interrupt 5.                                |  |
|    |      |     |                                              | PA2: General purpose bidirectional digital I/O pin.  |  |
| 10 | DA 2 | L/O |                                              | MISO1: SPI1 serial data pin, host input; serial data |  |
|    |      |     | PA2                                          | input and output pin in SPI1 simplex mode.           |  |
| 48 | PA2  | I/O | /MISO1/LED2/CMD3/A2                          | LED2: LED serial data line 2.                        |  |
|    |      |     |                                              | CMD3: SD3 controller command signal line.            |  |
|    |      |     |                                              | A2: Parallel port address line 2.                    |  |

#### ATTENTION:

(1). I: Input; O: Output; P: Power.

- (2) USB: USB signal.
- (3) The priority of multiplexing functions of the pins in the table are arranged in order from high to low (excluding the main function GPIO function)

Remarks :

In order to be compatible with the power supply system of external devices, CH567 will divide the power supply of peripherals for management and IOs and provide multiple sets of power pins. In the above pin description, the pins marked with different colors belong to different power domains, and the assignments are as follows:

Font color: Same as power supply V33REG/V33USB Font color: Same as power supply V33IO1 Font color: Same as power supply V33IO2 Font color: Same as power supply V33IO3

## **Chapter 2 System Structure and Memory**

## 2.1 System Structure

The following figure shows the system structure block diagram of CH567 chip.



Figure 2-1 CH567 Internal Structure Block Diagram

The CPU core, DMA arbitration controller, SRAM and various peripheral modules are mounted on the 64bit system bus of CH567. The DMA controller can be used for modules such as USB, SATA, SD, SPI0, LED and TIMER of peripherals.

## 2.2 Memory Mapping

CH567 includes a 4GB address space, and the memory map mainly contains several different areas, as shown in the figure below.



Figure 2-2 Memory Mapping

## 2.3 Memory Mapping

The address range of each memory mapping area is shown in the table below:

| Table 2-1 Memory Mapping Area Address |  |
|---------------------------------------|--|
|                                       |  |

| Address range           | Usage                                    | Description                 |
|-------------------------|------------------------------------------|-----------------------------|
| 0x0000 0000-0x0003 FFFF | On-chip non-volatile memory              | Flash memory (256KB)        |
| 0x0004 0000-0x001F FFFF | Reserved                                 | -                           |
| 0x0020 0000-0X0020 7FFF | On-chip SRAM, usually used to store data | 32KB                        |
| 0x0020 8000-0x003F FFFF | Reserved                                 | -                           |
| 0x0040 0000-0x0040 FFFF | Various peripherals                      | Multiple peripheral modules |
| 0x0041 0000-0x007F FFFF | Reserved                                 | -                           |
| 0x0080 0000-0x0080 7FFF | External system bus                      | 32KB                        |
| 0x0080 8000-0xFFFF 7FFF | Reserved                                 | -                           |

## 2.4 Peripheral Address Assignment

**Peripheral No.** 

CH567 mainly contains the following peripherals. Each peripheral occupies a certain address space, and the actual access address of peripheral register is: base address + offset address. In the following chapters, the address of the register is described in detail. The following table shows the assignment of base address of each peripheral.

 Table 2-2 Peripheral Base Address Assignment

Peripheral name Peripheral base address

| 1  | SYS   | 0x0040 1000 |
|----|-------|-------------|
| 2  | TMR0  | 0x0040 2000 |
| 3  | TMR1  | 0x0040 2400 |
| 4  | TMR2  | 0x0040 2800 |
| 5  | UART0 | 0x0040 3000 |
| 6  | UART1 | 0x0040 3400 |
| 7  | UART2 | 0x0040 3800 |
| 8  | UART3 | 0x0040 3C00 |
| 9  | SPI0  | 0x0040 4000 |
| 10 | SPI1  | 0x0040 4400 |
| 11 | PWMX  | 0x0040 5000 |
| 12 | LED   | 0x0040 6000 |
| 13 | USB0  | 0x0040 8000 |
| 14 | USB1  | 0x0040 9000 |
| 15 | SDC   | 0x0040 A000 |
| 16 | ECDC  | 0x0040 C400 |

The following table is the explanation of "Access" in the register description in the subsequent chapters:

| Abbreviation                                                 | Description                                              |
|--------------------------------------------------------------|----------------------------------------------------------|
| RF                                                           | The read value is fixed, which is not affected by reset. |
| RO                                                           | Read only.                                               |
| WO                                                           | Write only (the read value is 0 or invalid).             |
| RZ Read-only, automatically cleared after read operation.    |                                                          |
| WZ Write to clear.                                           |                                                          |
| RW Readable, writable.                                       |                                                          |
| RW1                                                          | Cleared by reading/writing 1.                            |
| WA Write-only (in safety mode), the read value is 0 or inval |                                                          |
| RWA Write in read/safety mode.                               |                                                          |

## **Chapter 3 System Control**

## **3.1 Power Control**

CH567 needs an external supply voltage of 3.3V. In the package pin description of Figure 1-1, multiple sets of power and ground are provided externally. Internal power management is provided with multi-power-domain grouping mode, which can connect different power systems according to the peripheral resources used.

After the system or power supply is reset, CH567 is in run state. When the CPU does not need to continue to run, or some functional modules do not need to be used, the clock or independent supply of these modules can be turned off, to reduce power consumption.

## **3.2 Reset Control**

CH567 supports 3 types of reset forms, namely power-on reset, external manual reset and internal software reset. System will reload the configuration information and reload the program code into the RAM buffer after reset. The load time is about 8.8mS.

The register R8\_GLOB\_RESET\_KEEP is only reset when power-on reset, and it is not affected by other types of reset.

#### 3.2.1 Power-on Reset

When the power supply voltage is lower than the power-on reset threshold Vpot, CH567 will be reset. The figure below shows the power-on reset of CH567.



Figure 3-1 Power-on Reset

#### **3.2.2 External Manual Reset**

The external manual reset is generated by the low level applied to the RST# pin from the external. When the reset low level duration is greater than the minimum reset pulse width (Trst), the chip will be triggered to reset.





## 3.2.3 Internal Software Reset

The chip is provided with the internal software reset function, so that no external intervention is required to perform software reset in some specific situations. Set the bit RB\_SOFTWARE\_RESET of global reset configuration register (R8\_RST\_WDOG\_CTRL) to 1, to realize software reset. This bit will be automatically cleared.

#### 3.2.4 Reset Feature

Please refer to the timing parameter table in section 15.4 for reset parameters.

## **3.3 Register Description**

System control related register physical base address: 0x0040 1000

| Name               | Offset address | Description                         | Reset value |
|--------------------|----------------|-------------------------------------|-------------|
| R8_SAFE_ACCESS_SIG | 0x00           | Secure access flag register         | 8h00        |
| R8_CHIP_ID         | 0x01           | Chip ID register                    | 8h68        |
| R8_SAFE_ACCESS_ID  | 0x02           | Secure access ID register           | 8h02        |
| R8_GLOB_ROM_CFG    | 0x04           | ROM configuration register          | 8h80        |
| R8_RST_BOOT_STAT   | 0x05           | BOOT status register                | 8hC1        |
| R8_RST_WDOG_CTRL   | 0x06           | Reset register                      | 8h00        |
| R8_GLOB_RESET_KEEP | 0x07           | Reset keep register                 | 8h00        |
| R8_SLP_WAKE_CTRL   | 0x0E           | Wake-up control register            | 8h00        |
| R8_SLP_POWER_CTRL  | 0x0F           | Low-power power management register | 8h00        |

| Table 3-1 | List of Clock ar | nd CPU Control | Related Registers |
|-----------|------------------|----------------|-------------------|
|           |                  |                |                   |

Security access flag register (R8\_SAFE\_ACCESS\_SIG):

| Bit   | Name               | Access | Description                                                                                                                                                                                                                                                                 | Reset<br>value |
|-------|--------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_SAFE_ACCESS_SIG | WO     | Secure access flag register.<br>Some registers (access attribute is RWA) are<br>protected registers, read/write operation can<br>be performed only after entering the secure<br>access mode. Write 0x57 first and then 0xA8<br>to this register, to enter the secure access | 00h            |

|       |                   |    | mode. And the time is limited to about 110 main clock cycles (Tsys), and it will be automatically protected beyond the time limit. |   |
|-------|-------------------|----|------------------------------------------------------------------------------------------------------------------------------------|---|
| [6:4] | RB_SAFE_ACC_TIMER | RO | Secure access time, fixed at 128 Tsys                                                                                              | 0 |
| [1:0] | RB_SAFE_ACC_MODE  | RO | Current secure access mode status:<br>11: Secure mode, registers with RWA attribute<br>can be accessed;<br>Other: Non-secure mode; | 0 |

Chip ID register (R8\_CHIP\_ID)

| Bit   | Name       | Access | Description                                    | Reset<br>value |
|-------|------------|--------|------------------------------------------------|----------------|
| [7:0] | R8_CHIP_ID | RF     | Fixed value of 67h, used to identify the chip. | 67h            |

## Secure access ID register (R8\_SAFE\_ACCESS\_ID):

| Bit   | Name              | Access | Description         | Reset<br>value |
|-------|-------------------|--------|---------------------|----------------|
| [7:0] | R8_SAFE_ACCESS_ID | RF     | Fixed value of 02h. | 02h            |

## ROM configuration register (R8\_GLOB\_ROM\_CFG):

| Bit   | Name           | Access | Description                                       | Reset<br>value |
|-------|----------------|--------|---------------------------------------------------|----------------|
| [7:4] | Reserved       | RWA    | Reserved, must write 01b to [7:6], the read is 0. | 0000b          |
|       |                |        | Flash ROM code and data area erase/program        |                |
| 3     | RB ROM CODE WE | RWA    | enable bit:                                       | 0              |
|       |                |        | 1: Programmable/erasable;                         |                |
|       |                |        | 0: Write protection                               |                |
|       |                |        | Flash ROM data area erase/program enable bit:     |                |
| 2     | RB_ROM_DATA_WE | RWA    | 1: Programmable/erasable;                         | 0              |
|       |                |        | 0: Write protection.                              |                |
|       |                |        | Code RAM area write enable bit:                   |                |
| 1     | RB_CODE_RAM_WE | RWA    | 1: Write enabled;                                 | 0              |
|       |                |        | 0: Write protection.                              |                |
|       |                |        | External programmer read Flash ROM enable         |                |
| 0     | DD DOM EVT DE  | RO     | bit:                                              | 0              |
| 0     | RB_ROM_EXT_RE  | ĸŪ     | 1: Read enabled;                                  | 0              |
|       |                |        | 0: Read protection.                               |                |

## BOOT status register (R8\_RST\_BOOT\_STAT)

| Bit   | Name            | Access | Description                          | Reset<br>value |
|-------|-----------------|--------|--------------------------------------|----------------|
| [7:6] | Reserved        | RO     | Reserved.                            | 11b            |
|       |                 |        | Boot loader status:                  |                |
| 5     | RB_BOOT_LOADER  | RO     | 1: Boot loader status (Boot-Loader); | 0              |
|       |                 |        | 0: User program status.              |                |
|       |                 |        | Debugging enable control bit:        |                |
| 4     | RB_CFG_DEBUG_EN | RO     | 1: Enable;                           | 0              |
|       |                 |        | 0: Disable.                          |                |

Relevant information can be downloaded from the website: www.wch.cn

11

| 3     | RB_CFG_BOOT_EN  | RO | Boot program enable control bit:<br>1: Enable;<br>0: Disable.                                  | 0 |
|-------|-----------------|----|------------------------------------------------------------------------------------------------|---|
| 2     | RB_CFG_RESET_EN | RO | External reset enable control bit:<br>1: External input low-level signal reset;<br>0: Disable. | 0 |
| [1:0] | RB_RESET_FLAG   | RO | Last reset flag, as shown in Table 3-2.                                                        | 1 |

## Table 3-2 Last Reset Flag Description

| RB_RESET_FLAG | Reset Flag Description                                                              |
|---------------|-------------------------------------------------------------------------------------|
| 00b           | Software reset, source: RB_SOFTWARE_RESET=1 and RB_BOOT_LOADER=0.                   |
| 01b           | Power on reset, source: Chip operating voltage is lower than the threshold voltage. |
| 11b           | Manual reset, source: RST# pin input low level.                                     |

#### Reset register (R8\_RST\_WDOG\_CTRL)

| Bit   | Name              | Access    | Description                                                                       | Reset<br>value |
|-------|-------------------|-----------|-----------------------------------------------------------------------------------|----------------|
| [7:1] | Reserved          | RO        | Reserved, must write 01b to [7:6].                                                | 00h            |
| 0     | RB_SOFTWARE_RESET | WA/<br>WZ | System software reset; cleared automatically:<br>1: System reset;<br>0: No action | 0              |

## Reset keep register (R8\_GLOB\_RESET\_KEEP)

| Bit   | Name               | Access | Description                                                                                                              | Reset<br>value |
|-------|--------------------|--------|--------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_GLOB_RESET_KEEP | RW     | Reset keep register. The value of this register is<br>not affected by manual reset, software reset or<br>watchdog reset. | 00h            |

## Wake-up control register (R8\_SLP\_WAKE\_CTRL)

| Bit   | Name             | Access | Description                                                        | Reset<br>value |
|-------|------------------|--------|--------------------------------------------------------------------|----------------|
| [7:5] | Reserved         | RO     | Reserved.                                                          | 0              |
| 4     | RB_SLP_GPIO_WAKE | RWA    | GPIO port wake-up enable control bit:<br>1: Enable;<br>0: Disable. | 0              |
| [3:2] | Reserved         | RO     | Reserved.                                                          | 0              |
| 1     | RB_SLP_USB1_WAKE | RWA    | USB1 wake-up enable control bit:<br>1: Enable;<br>0: Disable.      | 0              |
| 0     | RB_SLP_USB0_WAKE | RWA    | USB0 wake-up enable control bit:<br>1: Enable;<br>0: Disable.      | 0              |

## Low-power power management register (R8\_SLP\_POWER\_CTRL)

| Bit | Name           | Access | Description                               | Reset<br>value |
|-----|----------------|--------|-------------------------------------------|----------------|
| 7   | RB_SLP_STANDBY | RWA    | Low-power mode control bit; automatically | 0              |

|       |                   |     | cleared after entering the mode: |   |
|-------|-------------------|-----|----------------------------------|---|
|       |                   |     | 1: Request core low power;       |   |
|       |                   |     | 0: No action.                    |   |
| [6:2] | Reserved          | RO  | Reserved.                        | 0 |
|       |                   |     | USB1 power control bit:          |   |
| 1     | RB_SLP_USB1_PWRDN | RWA | 1: Power off;                    | 0 |
|       |                   |     | 0: Power on normally.            |   |
|       |                   |     | USB0 power control bit:          |   |
| 0     | RB_SLP_USB0_PWRDN | RWA | 1: Power off;                    | 0 |
|       |                   |     | 0: Power on normally.            |   |

## 3.4 Low Power Mode and Wake-up

In the low-power state (RB\_SLP\_STANDBY bit is set to 1), the PLL will stop working, the internal clock of CH567 will be suspended, the CPU will not work or respond to any interrupts. However, if CPU starts working after waking up, and it is found that the wake-up event is also an interrupt event (for example, a certain GPIO wakes up and GPIO interrupt is generated), it will be treated as an interrupt.

In order to reduce power, the physical PHY module (such as USB) that is not used during the low power period shall be turned off before entering the low power state. Set RB\_SLP\_USB0\_PWRDN bit to 1, and set RB\_SLP\_USB1\_PWRDN bit to 1. In addition, GPIO pins cannot be in floating state, and need to be set to output state or input state with an external fixed level. If there is no external input with a fixed level, they need to be set to input state under internal pull-down mode.

In low power mode, CH567 only supports the wake-up of part of GPIO or USB, please refer to R8 SLP WAKE CTRL register.

There are 8 GPIO pins that support wake-up, which are 8 pins that support GPIO interrupt. GPIO wake-up event source is the same as the GPIO interrupt event source, but only triggered by level (R8\_GPIO\_INT\_MODE is not required). When the bit corresponding to R8\_GPIO\_INT\_POLAR is 0, a low level occurs on GPIO pin, then it will wake up. When the bit corresponding to R8\_GPIO\_INT\_POLAR is 1, a high level occurs on GPIO pin, then it will wake up.

Take GPIO port PA3 wake-up as an example, the configuration is as follows:

RB\_GPIO\_PA3\_IP=0;

RB\_GPIO\_PA3\_IE=1;

RB SLP GPIO WAKE=1;

When a low level occurs at PA3 port, a wake-up event will be generated. After CH567 exits the low-power mode, it will trigger the GPIO interrupt of PA3 port.

## **Chapter 4 Clock Control**

## 4.1 Clock Block Diagram

The internal clock structure of CH567 is shown in the figure below:



Figure 4-1 Clock Structure Block Diagram

After the external clock is sent to CH567, it will be connected to USB-PHY to generate the clock frequency required by USB controller, and generate the frequency multiplication clock of 480MHz through the PLL module. Get the clock frequency of 30MHz or 480MHz before frequency division through the clock source selection control bit (RB CLK SEL PLL). At this time, the clock frequency will get the system

clock Fsys (HCLK) through the frequency divider (R8\_CLK\_PLL\_DIV), namely the main clock of CPU, with a range of 2MHz-120MHz.

Each peripheral module clock has a corresponding clock register control bit, which can be turned on or off independently. In order to reduce the power of chip, you can turn off the function module clocks that are not used.

## **4.2 Register Description**

Clock control related register physical base address: 0x0040 1000

| 8               |                |                                   |             |  |
|-----------------|----------------|-----------------------------------|-------------|--|
| Name            | Offset address | Description                       | Reset value |  |
| R8_CLK_PLL_DIV  | 0x08           | PLL output clock divider register | 8h42        |  |
| R8_CLK_CFG_CTRL | 0x0A           | Clock configuration register      | 8h80        |  |
| R8_SLP_CLK_OFF0 | 0x0C           | Sleep control register 0          | 8h00        |  |
| R8_SLP_CLK_OFF1 | 0x0D           | Sleep control register 1          | 8h00        |  |

Table 4-1 List of Clock Control Related Registers

#### PLL output clock divider register (R8\_CLK\_PLL\_DIV)

| Bit   | Name           | Access | Description                                                                      | Reset<br>value |
|-------|----------------|--------|----------------------------------------------------------------------------------|----------------|
| [7:0] | R8_CLK_PLL_DIV | RWA    | The lower 4 bits are valid, must write 01b to [7:6], and the minimum value is 2. | 8h42           |

#### Clock configuration register (R8\_CLK\_CFG\_CTRL)

| Bit   | Name             | Access | Description                              | Reset<br>value |
|-------|------------------|--------|------------------------------------------|----------------|
| [7:2] | Reserved         | RWA    | Reserved, must write 01b to [7:6].       | 100000b        |
|       |                  |        | Clock source selection:                  |                |
| 1     | RB_CLK_SEL_PLL   | RWA    | 1:PLL 480MHz;                            | 0              |
|       |                  |        | 0: External crystal oscillator of 30MHz. |                |
|       |                  |        | PLL sleep control bit:                   |                |
| 0     | RB_CLK_PLL_SLEEP | RWA    | 1: PLL sleep;                            | 0              |
|       |                  |        | 0: PLL works normally.                   |                |

#### Sleep control register 0 (R8 SLP CLK OFF0)

| Bit | Name             | Access | Description                                                                               | Reset<br>value |
|-----|------------------|--------|-------------------------------------------------------------------------------------------|----------------|
| 7   | RB_SLP_CLK_UART3 | RWA    | UART3 clock control bit:<br>1: UART3 clock is turned off;<br>0: UART3 clock is turned on. | 0              |
| 6   | RB_SLP_CLK_UART2 | RWA    | UART2 clock control bit:<br>1: UART2 clock is turned off;<br>0: UART2 clock is turned on. | 0              |
| 5   | RB_SLP_CLK_UART1 | RWA    | UART1 clock control bit:<br>1: UART1 clock is turned off;<br>0: UART1 clock is turned on. | 0              |
| 4   | RB_SLP_CLK_UART0 | RWA    | UART0 clock control bit:<br>1: UART0 clock is turned off;                                 | 0              |

|   |                 |     | 0: UART0 clock is turned on.   |   |
|---|-----------------|-----|--------------------------------|---|
|   |                 |     | PWM clock control bit:         |   |
| 3 | RB_SLP_CLK_PWMX | RWA | 1: PWM clock is turned off;    | 0 |
|   |                 |     | 1: PWM clock is turned on.     |   |
|   |                 |     | TIMER2 clock control bit:      |   |
| 2 | RB_SLP_CLK_TMR2 | RWA | 1: TIMER2 clock is turned off; | 0 |
|   |                 |     | 0: TIMER2 clock is turned on.  |   |
|   |                 |     | TIMER1 clock control bit:      |   |
| 1 | RB_SLP_CLK_TMR1 | RWA | 1: TIMER1 clock is turned off; | 0 |
|   |                 |     | 0: TIMER1 clock is turned on.  |   |
|   |                 |     | TIMER0 clock control bit:      |   |
| 0 | RB_SLP_CLK_TMR0 | RWA | 1: TIMER0 clock is turned off; | 0 |
|   |                 |     | 0: TIMER0 clock is turned on.  |   |

Sleep control register 1 (R8\_SLP\_CLK\_OFF1)

| Bit | Name            | Access | Description                                                                                                                                               | Reset<br>value |
|-----|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | RB_SLP_CLK_ECDC | RWA    | <ul><li>ECDC (encryption/decryption module) clock</li><li>control bit:</li><li>1: ECDC clock is turned off;</li><li>1: ECDC clock is turned on.</li></ul> | 0              |
| 6   | Reserved        | RO     | Reserved.                                                                                                                                                 | 0              |
| 5   | RB_SLP_CLK_USB1 | RWA    | USB clock control bit:<br>1: USB clock is turned off;<br>1: USB clock is turned on.                                                                       | 0              |
| 4   | RB_SLP_CLK_USB0 | RWA    | USB0 clock control bit:<br>1: USB0 clock is turned off;<br>0: USB0 clock is turned on.                                                                    | 0              |
| 3   | RB_SLP_CLK_LED  | RWA    | LEDC clock control bit:<br>1: LEDC clock is turned off;<br>1: LEDC clock is turned on.                                                                    | 0              |
| 2   | RB_SLP_CLK_SDC  | RWA    | <ul><li>SDC clock control bit:</li><li>1: SDC clock is turned off;</li><li>1: SDC clock is turned on.</li></ul>                                           | 0              |
| 1   | RB_SLP_CLK_SPI1 | RWA    | <ul><li>SPI1 clock control bit:</li><li>1: SPI1 clock is turned off;</li><li>0: SPI1 clock is turned on.</li></ul>                                        | 0              |
| 0   | RB_SLP_CLK_SPI0 | RWA    | <ul><li>SPI0 clock control bit:</li><li>1: SPI0 clock is turned off;</li><li>0: SPI0 clock is turned on.</li></ul>                                        | 0              |

## 4.3 System Clock Configuration

External crystal oscillator clock: Fosc = 30MHz;

PLL frequency multiplication clock: Fpll = 480MHz;

1. Select PLL clock source: Fsrc = RB CLK SEL PLL? PLL FREQ : OSC FREQ;

2. System clock calculation: Fsys = Fsrc / R8\_CLK\_PLL\_DIV, (2MHz - 120MHz).

When the system is powered on, 30MHz is selected as the PLL clock source by default, the frequency division factor is 2, and the default main frequency is 15MHz.

## Chapter 5 General purpose and Multiplexing I/O

## 5.1 Introduction to GPIO

The system is equipped with 2 sets of GPIO ports of PA and PB, with a total of 30 general purpose input/output pins, and some pins have multiplexing and mapping functions. Each GPIO port has a 32-bit direction configuration register (R32\_Px\_DIR), a 32-bit data input register (R32\_Px\_PIN), a 32-bit data clear register (R32\_Px\_CLR), a 32-bit pull-up configuration register (R32\_Px\_PU), a 32-bit open drain output and input pull-down configuration register (R32\_Px\_PD), a 32-bit I/O drive capability configuration register (R32\_Px\_DRV) and a 32-bit Schmitt trigger enable configuration register (R32\_Px\_SMT).

In the PA port, the PA[0]-PA[15] bits are valid, corresponding to the 16 GPIO pins on the chip. In the PB port, the PB[0]-PB[13] bits are valid, corresponding to the 14 GPIO pins on the chip. Among them, 8 GPIO ports have interrupt function and can realize sleep and wake-up function.

Each I/O port bit can be freely programmed, but the I/O port register must be accessed by 8-bit, 16-bit or 32-bit words. If the multiplexing function of pin is not enabled, it will be used as a general-purpose I/O port.

The following figure is a block diagram of the internal structure of GPIO:



Figure 5-1 IO Internal Structure Block Diagram

## **5.2 Register Description**

GPIO related register physical base address: 0x0040 1000

| Name               | Offset address | Description                          | Reset value |
|--------------------|----------------|--------------------------------------|-------------|
| R8_GPIO_INT_STATUS | 0x1C           | GPIO interrupt flag register         | 8h00        |
| R8_GPIO_INT_ENABLE | 0x1D           | GPIO interrupt enable register       | 8h00        |
| R8_GPIO_INT_MODE   | 0x1E           | GPIO interrupt trigger mode register | 8h00        |
| R8_GPIO_INT_POLAR  | 0x1F           | GPIO interrupt polarity register     | 8h00        |

Table 5-1 List of GPIO Related Registers

| R32_PA_DIR  | 0x40 | PA port direction setting register                                   | 32h0000 0000 |
|-------------|------|----------------------------------------------------------------------|--------------|
| R32_PA_PIN  | 0x44 | PA port data input register                                          | 32hxxxx xxxx |
| R32_PA_OUT  | 0x48 | PA port data output register                                         | 32h0000 0000 |
| R32_PA_CLR  | 0x4C | PA port output clear register                                        | 32h0000 0000 |
| R32_PA_PU   | 0x50 | PA port pull-up enable register                                      | 32h0000 0000 |
| R32_PA_PD   | 0x54 | PA port open-drain output and input pull-down configuration register | 32h0000 0000 |
| R32_PA_DRV  | 0x58 | PA port drive capability configuration register                      | 32h0000 0000 |
| R32_PA_SMT  | 0x5C | PA port Schmitt trigger enable configuration register                | 32h0000 0000 |
| R32_PB_DIR  | 0x60 | PB port direction setting register                                   | 32h0000 0000 |
| R32_PB_PIN  | 0x64 | PB port data input register                                          | 32hxxxx 8000 |
| R32_PB_OUT  | 0x68 | PB port data output register                                         | 32h0000 0000 |
| R32_PB_CLR  | 0x6C | PB port output clear register                                        | 32h0000 0000 |
| R32_PB_PU   | 0x70 | PB port pull-up configuration register                               | 32h0000 0000 |
| R32_PB_PD   | 0x74 | PB port open-drain output and input pull-down configuration register | 32h0000 0000 |
| R32_PB_DRV  | 0x78 | PB port drive capability configuration register                      | 32h0000 0000 |
| R32_PB_SMT  | 0x7C | PB port Schmitt trigger enable configuration register                | 32h0000 0000 |
| R8_PORT_PIN | 0x12 | Multiplexing and remapping configuration register                    | 8h00         |

## GPIO interrupt flag register (R8\_GPIO\_INT\_STATUS)

| Bit | Name            | Access | Description                                        | Reset<br>value |
|-----|-----------------|--------|----------------------------------------------------|----------------|
|     |                 |        | PB10 pin interrupt flag bit, cleared by writing 1: |                |
| 7   | RB_GPIO_PB10_IS | RW1    | 1: An interrupt is generated;                      | 0              |
|     |                 |        | 0: No interrupt is generated.                      |                |
|     |                 |        | PB4 pin interrupt flag bit, cleared by writing 1:  |                |
| 6   | RB_GPIO_PB4_IS  | RW1    | 1: An interrupt is generated;                      | 0              |
|     |                 |        | 0: No interrupt is generated.                      |                |
|     |                 |        | PA12 pin interrupt flag bit, cleared by writing 1: |                |
| 5   | RB_GPIO_PA12_IS | RW1    | 1: An interrupt is generated;                      | 0              |
|     |                 |        | 0: No interrupt is generated.                      |                |
|     |                 |        | PA11 pin interrupt flag bit, cleared by writing 1: |                |
| 4   | RB_GPIO_PA11_IS | RW1    | 1: An interrupt is generated;                      | 0              |
|     |                 |        | 0: No interrupt is generated.                      |                |
|     |                 |        | PA10 pin interrupt flag bit, cleared by writing 1: |                |
| 3   | RB_GPIO_PA10_IS | RW1    | 1: An interrupt is generated;                      | 0              |
|     |                 |        | 0: No interrupt is generated.                      |                |
|     |                 |        | PA6 pin interrupt flag bit, cleared by writing 1:  |                |
| 2   | RB_GPIO_PA6_IS  | RW1    | 1: An interrupt is generated;                      | 0              |
|     |                 |        | 0: No interrupt is generated.                      |                |
| 1   |                 | DW1    | PA4 pin interrupt flag bit, cleared by writing 1:  | 0              |
| 1   | RB_GPIO_PA4_IS  | RW1    | 1: An interrupt is generated;                      | 0              |

|   |                |     | 0: No interrupt is generated.                   |   |
|---|----------------|-----|-------------------------------------------------|---|
|   |                |     | PA3 pin interrupt flag bit, clear by writing 1: |   |
| 0 | RB_GPIO_PA3_IS | RW1 | 1: An interrupt is generated;                   | 0 |
|   |                |     | 0: No interrupt is generated.                   |   |

## GPIO interrupt enable register (R8\_GPIO\_INT\_ENABLE)

| Bit | Name            | Access | Description                             | Reset<br>value |
|-----|-----------------|--------|-----------------------------------------|----------------|
|     |                 |        | PB10 pin interrupt enable bit:          |                |
| 7   | RB_GPIO_PB10_IE | RW     | 1: Enable the corresponding interrupt;  | 0              |
|     |                 |        | 0: Disable the corresponding interrupt. |                |
|     |                 |        | PB4 pin interrupt enable bit:           |                |
| 6   | RB_GPIO_PB4_IE  | RW     | 1: Enable the corresponding interrupt;  | 0              |
|     |                 |        | 0: Disable the corresponding interrupt. |                |
|     |                 |        | PA12 pin interrupt enable bit:          |                |
| 5   | RB_GPIO_PA12_IE | RW     | 1: Enable the corresponding interrupt;  | 0              |
|     |                 |        | 0: Disable the corresponding interrupt. |                |
|     |                 |        | PA11 pin interrupt enable bit:          |                |
| 4   | RB_GPIO_PA11_IE | RW     | 1: Enable the corresponding interrupt;  | 0              |
|     |                 |        | 0: Disable the corresponding interrupt. |                |
|     |                 |        | PA10 pin interrupt enable bit:          |                |
| 3   | RB_GPIO_PA10_IE | RW     | 1: Enable the corresponding interrupt;  | 0              |
|     |                 |        | 0: Disable the corresponding interrupt. |                |
|     |                 |        | PA6 pin interrupt enable bit:           |                |
| 2   | RB_GPIO_PA6_IE  | RW     | 1: Enable the corresponding interrupt;  | 0              |
|     |                 |        | 0: Disable the corresponding interrupt. |                |
|     |                 |        | PA4 pin interrupt enable bit:           |                |
| 1   | RB_GPIO_PA4_IE  | RW     | 1: Enable the corresponding interrupt;  | 0              |
|     |                 |        | 0: Disable the corresponding interrupt. |                |
|     |                 |        | PA3 pin interrupt enable bit:           |                |
| 0   | RB_GPIO_PA3_IE  | RW     | 1: Enable the corresponding interrupt;  | 0              |
|     |                 |        | 0: Disable the corresponding interrupt. |                |

## GPIO interrupt trigger mode register (R8\_GPIO\_INT\_MODE)

| Bit | Name            | Access | Description                            | Reset<br>value |
|-----|-----------------|--------|----------------------------------------|----------------|
|     |                 |        | PB10 pin interrupt mode selection bit: |                |
| 7   | RB_GPIO_PB10_IM | RW     | 1: Edge trigger;                       | 0              |
|     |                 |        | 0: Level trigger.                      |                |
|     |                 |        | PB4 pin interrupt mode selection bit:  |                |
| 6   | RB_GPIO_PB4_IM  | RW     | 1: Edge trigger;                       | 0              |
|     |                 |        | 0: Level trigger.                      |                |
|     |                 |        | PA12 pin interrupt mode selection bit: |                |
| 5   | RB_GPIO_PA12_IM | RW     | 1: Edge trigger;                       | 0              |
|     |                 |        | 0: Level trigger.                      |                |
|     |                 |        | PA11 pin interrupt mode selection bit: |                |
| 4   | RB_GPIO_PA11_IM | RW     | 1: Edge trigger;                       | 0              |
|     |                 |        | 0: Level trigger.                      |                |
| 3   | RB_GPIO_PA10_IM | RW     | PA10 pin interrupt mode selection bit: | 0              |

|   |                |    | 1: Edge trigger;                      |   |
|---|----------------|----|---------------------------------------|---|
|   |                |    | 0: Level trigger.                     |   |
|   |                |    | PA6 pin interrupt mode selection bit: |   |
| 2 | RB_GPIO_PA6_IM | RW | 1: Edge trigger;                      | 0 |
|   |                |    | 0: Level trigger.                     |   |
|   |                |    | PA4 pin interrupt mode selection bit: |   |
| 1 | RB_GPIO_PA4_IM | RW | 1: Edge trigger;                      | 0 |
|   |                |    | 0: Level trigger.                     |   |
|   |                |    | PA3 pin interrupt mode selection bit: |   |
| 0 | RB_GPIO_PA3_IM | RW | 1: Edge trigger;                      | 0 |
|   |                |    | 0: Level trigger.                     |   |

## GPIO interrupt polarity register (R8\_GPIO\_INT\_POLAR)

| Bit | Name            | Access | Description                                | Reset<br>value |
|-----|-----------------|--------|--------------------------------------------|----------------|
|     |                 |        | PB10 pin interrupt polarity selection bit: |                |
| 7   | RB_GPIO_PB10_IP | RW     | 1: High level/rising edge;                 | 0              |
|     |                 |        | 0: Low level/falling edge.                 |                |
|     |                 |        | PB4 pin interrupt polarity selection bit:  |                |
| 6   | RB_GPIO_PB4_IP  | RW     | 1: High level/rising edge;                 | 0              |
|     |                 |        | 0: Low level/falling edge.                 |                |
|     |                 |        | PA12 pin interrupt polarity selection bit: |                |
| 5   | RB_GPIO_PA12_IP | RW     | 1: High level/rising edge;                 | 0              |
|     |                 |        | 0: Low level/falling edge.                 |                |
|     |                 |        | PA11 pin interrupt polarity selection bit: |                |
| 4   | RB_GPIO_PA11_IP | RW     | 1: High level/rising edge;                 | 0              |
|     |                 |        | 0: Low level/falling edge.                 |                |
|     |                 |        | PA10 pin interrupt polarity selection bit: |                |
| 3   | RB_GPIO_PA10_IP | RW     | 1: High level/rising edge;                 | 0              |
|     |                 |        | 0: Low level/falling edge.                 |                |
|     |                 |        | PA6 pin interrupt polarity selection bit:  |                |
| 2   | RB_GPIO_PA6_IP  | RW     | 1: High level/rising edge;                 | 0              |
|     |                 |        | 0: Low level/falling edge.                 |                |
|     |                 |        | PA4 pin interrupt polarity selection bit:  |                |
| 1   | RB_GPIO_PA4_IP  | RW     | 1: High level/rising edge;                 | 0              |
|     |                 |        | 0: Low level/falling edge.                 |                |
|     |                 |        | PA3 pin interrupt polarity selection bit:  |                |
| 0   | RB_GPIO_PA3_IP  | RW     | 1: High level/rising edge;                 | 0              |
|     |                 |        | 0: Low level/falling edge.                 |                |

## PA port direction setting register (R32\_PA\_DIR)

| Bit     | Name       | Access | Description                                                                                                                         | Reset<br>value |
|---------|------------|--------|-------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:16] | Reserved   | RO     | Reserved.                                                                                                                           | 0              |
| [15:0]  | R32_PA_DIR | RW     | Current input/output direction control of PA<br>pin:<br>1: The pin direction is output mode;<br>0: The pin direction is input mode. | 0              |

| Bit     | Name       | Access | Description                                                                                                                                                                                                                                | Reset<br>value |
|---------|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:16] | Reserved   | RO     | Reserved.                                                                                                                                                                                                                                  | 0              |
| [15:0]  | R32_PA_PIN | RO     | <ul> <li>PA pin level status:</li> <li>1: The pin inputs high level;</li> <li>0: The pin inputs low level;</li> <li>The value of this bit is valid only when the corresponding bit of the direction register (R32_PA_DIR) is 0.</li> </ul> | 0              |

## PA port output data register (R32\_PA\_OUT)

| Bit     | Name       | Access | Description                                                                                                                                                                                                                                         | Reset<br>value |
|---------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:16] | Reserved   | RO     | Reserved.                                                                                                                                                                                                                                           | 0              |
| [15:0]  | R32_PA_OUT | RW     | <ul> <li>PA pin output level status:</li> <li>1: The pin outputs high level;</li> <li>0: The pin outputs low level;</li> <li>The value of this bit is valid only when the corresponding bit of the direction register (R32_PA_DIR) is 1.</li> </ul> | 0              |

PA port bit clear register (R32\_PA\_CLR)

| Bit     | Name       | Access | Description                        | Reset<br>value |
|---------|------------|--------|------------------------------------|----------------|
| [31:16] | Reserved   | RO     | Reserved.                          | 0              |
|         |            |        | PA hold/clear data output control: |                |
| [15:0]  | R32_PA_CLR | WZ     | 1: The pin outputs low level;      | 0              |
|         |            |        | 0: No effect.                      |                |

## PA port pull-up configuration register (R32\_PA\_PU)

| Bit     | Name      | Access | Description                             | Reset<br>value |
|---------|-----------|--------|-----------------------------------------|----------------|
| [31:16] | Reserved  | RO     | Reserved.                               | 0              |
|         |           |        | PA pin pull-up function enable control: |                |
| [15:0]  | R32_PA_PU | RW     | 1: Enable pin pull-up function;         | 0              |
|         |           |        | 0: Disable pin pull-up function.        |                |

## PA port open-drain output and input pull-down configuration register (R32\_PA\_PD)

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                      | Reset<br>value |
|---------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:16] | Reserved  | RO     | Reserved.                                                                                                                                                                                                                                                                                                        | 0              |
| [15:0]  | R32_PA_PD | RW     | <ul> <li>When the corresponding bit of direction register</li> <li>(R32_PA_DIR) is configured as 1 (ie output mode):</li> <li>1: Enable open-drain output function of this pin;</li> <li>1: Disable open-drain output function of this pin.</li> <li>When the corresponding bit of direction register</li> </ul> | 0              |

| (R32_PA_DIR) is configured as 0 (ie input mode): |  |
|--------------------------------------------------|--|
| 1: Enable the pull-down function of this pin;    |  |
| 1: Disable the pull-down function of this pin;   |  |

## PA port drive capability configuration register (R32\_PA\_DRV)

| Bit     | Name       | Access | Description                             | Reset<br>value |
|---------|------------|--------|-----------------------------------------|----------------|
| [31:16] | Reserved   | RO     | Reserved.                               | 0              |
| 54 5 63 |            |        | PA pin output drive capability control: | <u>^</u>       |
| [15:0]  | R32_PA_DRV | RW     | 1: The maximum drive current is 16mA;   | 0              |
|         |            |        | 0: The maximum drive current is 8mA.    |                |

## PA port Schmitt trigger enable configuration register (R32\_PA\_SMT):

| Bit     | Name       | Access | Description                                                                                                                          | Reset<br>value |
|---------|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:16] | Reserved   | RO     | Reserved.                                                                                                                            | 0              |
|         |            |        | <ul><li>PA pin Schmitt trigger function control:</li><li>1: Enable the Schmitt trigger input function or</li></ul>                   |                |
| [15:0]  | R32_PA_SMT | RW     | low slope output function of this pin;<br>0: Disable the Schmitt trigger input function or<br>low slope output function of this pin. | 0              |

## PB port direction setting register (R32\_PB\_DIR)

| Bit     | Name       | Access | Description                                                                               | Reset<br>value |
|---------|------------|--------|-------------------------------------------------------------------------------------------|----------------|
| [31:14] | Reserved   | RO     | Reserved.                                                                                 | 0              |
| [13:0]  | R32_PB_DIR | RW     | Current input/output direction control of PB pin:<br>1: The pin direction is output mode; | 0              |
|         |            |        | 0: The pin direction is input mode.                                                       |                |

#### PB port input data register (R32\_PB\_PIN)

| Bit     | Name       | Access | Description                                                                                                                                                                                                           | Reset<br>value |
|---------|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:14] | Reserved   | RO     | Reserved.                                                                                                                                                                                                             | 0              |
| [13:0]  | R32_PB_PIN | RO     | Current level status of PB pin:<br>1: The pin inputs high level;<br>0: The pin inputs low level.<br>The value of this bit is valid only when the<br>corresponding bit of the direction register<br>(R32_PB_DIR) is 0. | 0              |

## PB port output data register (R32\_PB\_OUT)

| Bit     | Name       | Access | Description                                                   | Reset<br>value |
|---------|------------|--------|---------------------------------------------------------------|----------------|
| [31:14] | Reserved   | RO     | Reserved.                                                     | 0              |
| [13:0]  | R32_PB_OUT | RW     | PB pin output level status:<br>1: The pin outputs high level; | 0              |

| 1: The pin outputs low level.<br>The value of this bit is valid only when the |  |
|-------------------------------------------------------------------------------|--|
| corresponding bit of the direction register (R32_PB_DIR) is 1.                |  |

## PB port bit clear register (R32\_PB\_CLR)

| Bit     | Name       | Access | Description                                                                                                      | Reset<br>value |
|---------|------------|--------|------------------------------------------------------------------------------------------------------------------|----------------|
| [31:14] | Reserved   | RO     | Reserved.                                                                                                        | 0              |
| [13:0]  | R32_PB_CLR | WZ     | <ul><li>PB hold/clear data output control:</li><li>1: The pin outputs low level;</li><li>0: No effect.</li></ul> | 0              |

## PB port pull-up configuration register (R32\_PB\_PU)

| Bit     | Name      | Access | Description                                                                                                                                | Reset<br>value |
|---------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:14] | Reserved  | RO     | Reserved.                                                                                                                                  | 0              |
| [13:0]  | R32_PB_PU | RW     | <ul><li>PB pin pull-up function enable control:</li><li>1: Enable pin pull-up function;</li><li>0: Disable pin pull-up function.</li></ul> | 0              |

## PB port open-drain output and input pull-down configuration register (R32\_PB\_PD)

| Bit     | Name      | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset<br>value |
|---------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:14] | Reserved  | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0              |
| [13:0]  | R32_PB_PD | RW     | <ul> <li>When the corresponding bit of direction register (R32_PB_DIR) is configured as 1 (ie output mode):</li> <li>1: Enable open-drain output function of this pin;</li> <li>1: Disable open-drain output function of this pin;</li> <li>When the corresponding bit of direction register (R32_PB_DIR) is configured as 0 (ie input mode):</li> <li>1: Enable pull-down function of this pin;</li> <li>1: Disable pull-down function of this pin;</li> <li>If the corresponding bit of pull-up configuration register (R32_PB_PU) is also configured as 1, the input status weak hold function is enabled.</li> </ul> | 0              |

## PB port drive capability configuration register (R32\_PB\_DRV)

| Bit     | Name       | Access | Description                             | Reset<br>value |
|---------|------------|--------|-----------------------------------------|----------------|
| [31:14] | Reserved   | RO     | Reserved.                               | 0              |
| [13:0]  |            |        | PB pin output drive capability control: |                |
|         | R32_PB_DRV | RW     | 1: The maximum drive current is 16mA;   | 0              |
|         |            |        | 0: The maximum drive current is 8mA.    |                |

| Bit     | Name       | Access | Description                                                                                                                                                                                                                                                               | Reset<br>value |
|---------|------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:14] | Reserved   | RO     | Reserved.                                                                                                                                                                                                                                                                 | 0              |
| [13:0]  | R32_PB_SMT | RW     | <ul><li>PB pin Schmitt trigger function control:</li><li>1: Enable the Schmitt trigger input function or</li><li>low slope output function of this pin;</li><li>0: Disable the Schmitt trigger input function or</li><li>low slope output function of this pin.</li></ul> | 0              |

PB port Schmitt trigger enable configuration register (R32 PB SMT):

Multiplexing and remapping configuration register (R8\_PORT\_PIN)

| Bit   | Name         | Access | Description                                                                                             | Reset<br>value |
|-------|--------------|--------|---------------------------------------------------------------------------------------------------------|----------------|
| [7:6] | Reserved     | RO     | Reserved.                                                                                               | 0              |
| 5     | RB_PIN_UART1 | RW     | UART1 remapping configuration bit:<br>1: RXD1/TXD1 to PB8/PB9 pin;<br>0: RXD1/TXD1 to PA8/PA9 pin.      | 0              |
| 4     | RB_PIN_UART0 | RW     | UART0 remapping configuration bit:<br>1: RXD0/TXD0 to PA15/PA14 pin;<br>0: RXD0/TXD0 to PB4/PB7 pin.    | 0              |
| 3     | Reserved     | RO     | Reserved.                                                                                               | 0              |
| 2     | RB_PIN_TMR2  | RW     | TIMER2 remapping configuration bit:<br>1: TMR2/PWM6/CAP2 to PB11 pin;<br>0: TMR2/PWM6/CAP2 to PA11 pin. | 0              |
| 1     | RB_PIN_TMR1  | RW     | TIMER1 remapping configuration bit:<br>1: TMR1/PWM5/CAP1 to PB2 pin;<br>0: TMR1/PWM5/CAP1 to PA10 pin.  | 0              |
| 0     | Reserved     | RO     | Reserved.                                                                                               | 0              |

## 5.3 GPIO Multiplexing and Remapping

## 5.3.1 Multiplexing Function

Some I/O pins of chip have the function of multiplexing. After power on, all I/O pins have common I/O functions by default. After enabling different function modules, the corresponding pins are configured as corresponding function pins of each function module.

If a pin is multiplexed with multiple functions, and multiple functions are enabled, please refer to the function order in the "Multiplexing Function and Mapping" list in section 1.2 for the priority order of multiplexing function.

For example: If PA0 pin is multiplexed as /SCK1/LED0/CMD1, the clock function of SPI1 has priority, and the CMD1 function of SD1 controller has the lowest priority. In this way, among multiple multiplexing functions, the multiplexing functions with the relatively higher priority of the pin can be enabled while those with the lowest priority do not need to be used.

The following tables list the I/O pins used by each function module.

| Pin  | GPIO | Function Description                           |
|------|------|------------------------------------------------|
| SCS  | PA12 | Chip selection input pin of SPI0 slave         |
| SCK0 | PA13 | SPI0 serial clock pin, host output/slave input |

Table 5-2 Serial Peripheral Interface (SPI0)

| MOSI0 | PA14 | SPI0 serial data pin, host output/slave input |
|-------|------|-----------------------------------------------|
| MISO0 | PA15 | SPI0 serial data pin, host input/slave output |

Table 5-3 Serial Peripheral Interface (SPI1)

| Pin   | GPIO | Function Description                             |  |
|-------|------|--------------------------------------------------|--|
| SCK1  | PA0  | SPI1 serial clock output pin                     |  |
| MOSI1 | PA1  | SPI1 serial data output pin (only host function) |  |
| MISO1 | PA2  | SPI1 serial data input pin (only host function)  |  |

Table 5-4 Universal Asynchronous Receiver-Transmitter (UART0)

| Pin   | GPIO | Function Description                     |  |
|-------|------|------------------------------------------|--|
| RXD0  | PB4  | UART0 receiver input pin                 |  |
| TXD0  | PB7  | UART0 transmitter output pin             |  |
| RXD0_ | PA15 | RXD pin function mapping of UART0        |  |
| TXD0_ | PA14 | TXD pin function mapping of UART0        |  |
| DTR   | PB5  | MODEM signal of UART0; data terminal is  |  |
| DIK   | РБЈ  | ready                                    |  |
| RTS   | PB6  | MODEM signal of UART0; request to send   |  |
| CTS   | PB0  | MODEM signal of UART0; clear to send     |  |
| DSR   | PB1  | MODEM signal of UART0; data device is    |  |
| DSK   | FDI  | ready                                    |  |
| RI    | PB2  | MODEM signal of UART0; ring indicator    |  |
| DCD   | PB3  | MODEM signal of UART0; carrier detection |  |

## Table 5-5 Universal Asynchronous Receiver-Transmitter (UART1-3)

| Pin   | GPIO | Function Description              |  |
|-------|------|-----------------------------------|--|
| RXD1  | PA8  | UART1 receiver input pin          |  |
| TXD1  | PA9  | UART1 transmitter output pin      |  |
| RXD1_ | PB8  | RXD pin function mapping of UART1 |  |
| TXD1_ | PB9  | TXD pin function mapping of UART1 |  |
| RXD2  | PA6  | UART2 receiver input pin          |  |
| TXD2  | PA7  | UART2 transmitter output pin      |  |
| RXD3  | PA4  | UART3 receiver input pin          |  |
| TXD3  | PA5  | UART3 transmitter output pin      |  |

Table 5-6 SD Controller (SD0-3)

| Pin GPIO Function Description |      | Function Description   |
|-------------------------------|------|------------------------|
| SDCK                          | PA6  | SD0-3 clock signal pin |
| CMD0                          | PA7  | SD0 command signal pin |
| SD00                          | PA8  | SD0 data signal 0 pin  |
| SD01                          | PA9  | SD0 data signal 1 pin  |
| SD02                          | PA10 | SD0 data signal 2 pin  |
| SD03                          | PA11 | SD0 data signal 3 pin  |
| CMD1                          | PA0  | SD1 command signal pin |
| SD10                          | PA12 | SD1 data signal 0 pin  |
| SD11                          | PA13 | SD1 data signal 1 pin  |
| SD12                          | PA14 | SD1 data signal 2 pin  |

| SD13 | PA15 | SD1 data signal 3 pin  |
|------|------|------------------------|
| CMD2 | PA1  | SD2 command signal pin |
| SD20 | PB0  | SD2 data signal 0 pin  |
| SD21 | PB1  | SD2 data signal 1 pin  |
| SD22 | PB2  | SD2 data signal 2 pin  |
| SD23 | PB3  | SD2 data signal 3 pin  |
| CMD3 | PA2  | SD3 command signal pin |
| SD30 | PB4  | SD3 data signal 0 pin  |
| SD31 | PB5  | SD3 data signal 1 pin  |
| SD32 | PB6  | SD3 data signal 2 pin  |
| SD33 | PB7  | SD3 data signal 3 pin  |

Table 5-7 LED Control Card

| Pin  | GPIO | Function Description  |  |
|------|------|-----------------------|--|
| LED0 | PA0  | LED serial data 0 pin |  |
| LED1 | PA1  | LED serial data 1 pin |  |
| LED2 | PA2  | LED serial data 2 pin |  |
| LED3 | PA3  | LED serial data 3 pin |  |
| LEDC | PA4  | LED serial clock pin  |  |

Table 5-8 ISP Download (ISP)

| Pin  | GPIO | Function Description               |
|------|------|------------------------------------|
| SCS  | PA12 | ISP download chip select input pin |
| SCK  | PA13 | ISP download clock input pin       |
| MOSI | PA14 | ISP download data input pin        |
| MISO | PA15 | ISP download data output pin       |
| RST  | RST# | ISP download reset input pin       |

#### 5.3.2 Remapping

In order to optimize the peripheral number of the chip package, some multiplexing functions can be remapped to other pins. Remapping of the pin can be realized by means of setting the multiplexing and mapping register R8\_PORT\_PIN.

CH567 supports remapping of UART0, TIMER1 and TIMER2 peripheral pins, please refer to the following table for details:

| ······································ |             |               |  |  |
|----------------------------------------|-------------|---------------|--|--|
| <b>Peripheral Function</b>             | Default Pin | Remapping Pin |  |  |
| UART0                                  | PB4/PB7     | PA15/PA14     |  |  |
| UART1                                  | PA8/PA9     | PB8/PB9       |  |  |
| TIMER1/PWM5                            | PA10        | PB2           |  |  |
| TIMER2/PWM6                            | PA11        | PB11          |  |  |

| Table 5-9 | ) Remai | nning | Pin |
|-----------|---------|-------|-----|

## **Chapter 6 Serial Peripheral Interface (SPI)**

## 6.1 Introduction to SPI

SPI is a full-duplex serial interface. It can handle multiple masters and slaves connected to the specified bus. During data communication, there can only be one master and one slave for communication on the bus. Usually SPI interface consists of 4 pins: SPI chip selection pin (SCS), SPI clock pin (SCK), SPI serial data pin MISO (master input/slave output pin) and SPI serial data pin MOSI (master output/slave input pin).

CH567 chip has 2 SPI interfaces, and their respective characteristics are as follows: SPI0 features:

- (1). Support master mode and device mode;
- (2). Compatible with Serial Peripheral Interface (SPI) specification;
- (3). Support the data transmission mode 0 and mode 3;
- (4). 8-bit data transmission mode;
- (5). The clock frequency is close to half of Fsys;
- (6). 8-byte FIFO;
- (7). The device mode supports the first byte as command mode or data stream mode;
- (8). Support DMA data transmission.
- SPI1 features:
- (1). Only support master mode;
- (2). Support the data transmission mode 0 and mode 3;
- (3). 8-bit data transmission mode;
- (4). The maximum clock frequency is close to half of Fsys;
- (5). 8-byte FIFO.

## 6.2 Register Description

SPI0 related register physical start address: 0x0040 4000

SPI1 related register physical start address: 0X0040 4400

| Name                                   | Offset address | Description                                                                                          | Reset value |
|----------------------------------------|----------------|------------------------------------------------------------------------------------------------------|-------------|
| R8_SPI0_CTRL_MOD                       | 0x00           | SPI0 mode configuration register                                                                     | 8h00        |
| R8_SPI0_CTRL_CFG                       | 0x01           | SPI0 configuration register                                                                          | 8h00        |
| R8_SPI0_INTER_EN                       | 0x02           | SPI0 interrupt enable register                                                                       | 8h00        |
| R8_SPI0_CLOCK_DIV<br>R8_SPI0_SLAVE_PRE | 0x03           | SPI0 clock frequency division register<br>in master mode<br>SPI0 preset data register in device mode | 8h10        |
| R8_SPI0_BUFFER                         | 0x04           | SPI0 data buffer                                                                                     | 8hxx        |
| R8_SPI0_RUN_FLAG                       | 0x05           | SPI0 working status register                                                                         | 8h00        |
| R8_SPI0_INT_FLAG                       | 0x06           | SPI0 interrupt flag register                                                                         | 8h00        |
| R8_SPI0_FIFO_COUNT                     | 0x07           | SPI0 transceiver FIFO counter register                                                               | 8hxx        |
| R16_SPI0_TOTAL_CNT                     | 0x0C           | SPI0 transceiver data length register                                                                | 16hxxxx     |
| R8_SPI0_FIFO                           | 0x10           | SPI0 FIFO register                                                                                   | 8hxx        |
| R8_SPI0_FIFO_COUNT1                    | 0x13           | SPI0 transceiver FIFO counter register                                                               | 8hxx        |
| R16_SPI0_DMA_NOW                       | 0x14           | Current address of SPI0 DMA buffer                                                                   | 16hxxxx     |
| R16_SPI0_DMA_BEG                       | 0x18           | Start address of SPI0 DMA buffer                                                                     | 16hxxxx     |

Table 6-1 List of SPI0 Related Registers

| R16_SPI0_DMA_END | 0x1C | End address of SPI0 DMA buffer | 16hxxxx |
|------------------|------|--------------------------------|---------|

| Name                | Offset address | Description                            | <b>Reset value</b> |
|---------------------|----------------|----------------------------------------|--------------------|
| R8_SPI1_CTRL_MOD    | 0x00           | SPI1 mode configuration register       | 8h00               |
| R8_SPI1_CTRL_CFG    | 0x01           | SPI1 configuration register            | 8h00               |
| R8_SPI1_INTER_EN    | 0x02           | SPI1 interrupt enable register         | 8h00               |
| R8 SPI1 CLOCK DIV   | 0x03           | SPI1 clock frequency division register | 8hxx               |
| K8_SFII_CLOCK_DIV   |                | in master mode                         |                    |
| R8_SPI1_BUFFER      | 0x04           | SPI1 data buffer                       | 8hxx               |
| R8_SPI1_RUN_FLAG    | 0x05           | SPI1 working status register           | 8h00               |
| R8_SPI1_INT_FLAG    | 0x06           | SPI1 interrupt flag register           | 8h00               |
| R8_SPI1_FIFO_COUNT  | 0x07           | SPI1 transceiver FIFO counter register | 8hxx               |
| R16_SPI1_TOTAL_CNT  | 0x0C           | SPI1 transceiver data length register  | 16hxxxx            |
| R8_SPI1_FIFO        | 0x10           | SPI1 FIFO register                     | 8hxx               |
| R8_SPI1_FIFO_COUNT1 | 0x13           | SPI1 transceiver FIFO counter register | 8hxx               |

## Table 6-2 List of SPI1 Related Registers

SPI mode configuration register (R8\_SPIx\_CTRL\_MOD) (x=0/1)

| Bit | Name               | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                           | Reset<br>value |
|-----|--------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | RB_SPI_MISO_OE     | RW     | <ul><li>MISO pin output enable bit (can be used for data line switching direction in 2-wire mode):</li><li>1: MISO pin output enabled;</li><li>0: MISO pin output disabled.</li></ul>                                                                                                                                                                                                                                 | 0              |
| 6   | RB_SPI_MOSI_OE     | RW     | MOSI pin output enable bit:<br>1: MOSI pin output enabled;<br>0: MOSI pin output disabled.                                                                                                                                                                                                                                                                                                                            | 0              |
| 5   | RB_SPI_SCK_OE      | RW     | <ul><li>SCK pin output enable bit</li><li>1: SCK pin output enabled;</li><li>0: SCK pin output disabled.</li></ul>                                                                                                                                                                                                                                                                                                    | 0              |
| 4   | RB_SPI_FIFO_DIR    | RW     | <ul><li>FIFO direction setting bit:</li><li>1: Input mode (read data in host mode);</li><li>0: Output mode (write data in host mode).</li></ul>                                                                                                                                                                                                                                                                       | 0              |
| 3   | RB_SPI_SLV_CMD_MOD | RW     | <ul> <li>SPI0 device mode first byte configuration bit, only for SPI0:</li> <li>1: First byte command mode;</li> <li>0: Data stream mode.</li> <li>In the first byte command mode, it will be regarded as a command code when receiving the first-byte data after valid SPI chip selection, and RB_SPI_IF_FST_BYTE bit of interrupt flag register will be set to 1, This bit is only valid in device mode.</li> </ul> | 0              |
| 3   | RB_SPI_MST_SCK_MOD | RW     | <ul> <li>Host clock sampling mode configuration bit:</li> <li>1: Mode 3 (SCK is at high level in idle mode);</li> <li>0: Mode 0 (SCK is at low level in idle mode).</li> <li>This bit is only valid in host mode.</li> </ul>                                                                                                                                                                                          | 0              |
| 2   | RB_SPI_2WIRE_MOD   | RW     | 2-wire or 3-wire SPI mode configuration bit,                                                                                                                                                                                                                                                                                                                                                                          | 0              |

|   |                   |    | only for SPI0, SPI1 does not need this bit:<br>1: 2-wire mode (SCK, MISO); |   |
|---|-------------------|----|----------------------------------------------------------------------------|---|
|   |                   |    | 0: 3-wire mode (SCK, MOSI, MISO).                                          |   |
|   |                   |    | FIFO register and counter register clear bit:                              |   |
| 1 | RB_SPI_ALL_CLEAR  | RW | 1: Force to clear;                                                         | 1 |
|   |                   |    | 0: Not clear.                                                              |   |
|   |                   |    | SPI0 master/slave mode selection bit, only for                             |   |
|   |                   |    | SPI0                                                                       |   |
| 0 | RB_SPI_MODE_SLAVE | RW | 1: Device mode;                                                            | 0 |
|   |                   |    | 0: Host mode.                                                              |   |
|   |                   |    | Note: SPI1 does not support device mode.                                   |   |

## SPI configuration register (R8\_SPIx\_CTRL\_CFG) (x=0/1)

| Bit   | Name              | Access | Description                                                                                                                                                                         | Reset<br>value |
|-------|-------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:6] | Reserved          | RO     | Reserved.                                                                                                                                                                           | 0              |
| 5     | RB_SPI_BIT_ORDER  | RW     | <ul><li>SPI data bit order selection bit:</li><li>1: Low byte is in front;</li><li>0: High byte is in front.</li></ul>                                                              | 0              |
| 4     | RB_SPI_AUTO_IF    | RW     | Enable the function of automatically clearing<br>flag bit RB_SPI_IF_BYTE_END when<br>accessing BUFFER/FIFO:<br>1: Enable;<br>0: Disable.                                            | 0              |
| 3     | Reserved          | RO     | Reserved.                                                                                                                                                                           | 0              |
| 2     | RB_SPI_DMA_LOOP   | RW     | <ul><li>SPI0 DMA address loop enable bit:</li><li>1: Enable DMA address loop function;</li><li>0: Disable DMA address loop function.</li><li>Note: Not supported by SPI1.</li></ul> | 0              |
| 1     | Reserved          | RO     | Reserved.                                                                                                                                                                           | 0              |
| 0     | RB_SPI_DMA_ENABLE | RW     | <ul><li>SPI0 DMA enable/disable bit, only supported</li><li>by SPI0:</li><li>1: Enable DMA;</li><li>0: Disable DMA.</li></ul>                                                       | 0              |

Note: If the DMA address loop mode function is enabled, when the DMA address is added to the set end address, it will automatically loop to the set first address, without re-setting the DMA start address register (R16\_SPI0\_DMA\_BEG) and DMA end address register (R16\_SPI0\_DMA\_END).

| Bit | Name               | Access | Description                                                                                                                                                                                                                                                                                                                                                                     | Reset<br>value |
|-----|--------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | RB_SPI_IE_FST_BYTE | RW     | The first byte receiving interrupt enable bit in<br>slave mode, only supported by SPI0:<br>1: Enable receiving the first byte interrupt;<br>0: Disable receiving the first byte interrupt.<br>To enable this function, you need to set SPI<br>to device mode, and meanwhile it is required<br>to set RB_SPI_SLV_CMD_MOD bit to 1,<br>thus entering the first byte command mode. | 0              |

SPI interrupt enable register (R8\_SPIx\_INTER\_EN) (x=0/1)

| [6:5] | Reserved           | RO | Reserved.                                                                                                                                                                              | 0 |
|-------|--------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 4     | RB_SPI_IE_FIFO_OV  | RW | <ul><li>FIFO overflow interrupt enable bit, only supported by SPI0:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>           | 0 |
| 3     | RB_SPI_IE_DMA_END  | RW | <ul><li>DMA end interrupt enable bit, only supported by SPI0:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>                 | 0 |
| 2     | RB_SPI_IE_FIFO_HF  | RW | <ul><li>More than half FIFO interrupt enable bit:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>                             | 0 |
| 1     | RB_SPI_IE_BYTE_END | RW | <ul> <li>SPI single byte transmission completion<br/>interrupt enable bit:</li> <li>1: Enable the corresponding interrupt;</li> <li>0: Disable the corresponding interrupt.</li> </ul> | 0 |
| 0     | RB_SPI_IE_CNT_END  | RW | <ul><li>SPI all byte transmission completion<br/>interrupt enable bit:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>        | 0 |

## SPI master mode clock divider register (R8\_SPIx\_CLOCK\_DIV) (x=0/1)

| Bit   | Name             | Access | Description                                                                                                                                  | Reset<br>value |
|-------|------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_SPI_CLOCK_DIV | RW     | Frequency division factor in master mode,<br>the minimum value of is 2<br>SPI clock frequency =<br>main frequency/frequency division factor. | 10h            |

### Preset data register in SPI slave mode (R8\_SPI0\_SLAVE\_PRE)

| Bit   | Name              | Access | Description                                                                                                                           | Reset<br>value |
|-------|-------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_SPI0_SLAVE_PRE | RW     | Preset return data in SPI0 slave mode.<br>Used to receive the return data after first byte<br>of data.<br>Note: Not supported by SPI1 | 10h            |

#### SPI data buffer (R8\_SPIx\_BUFFER) (x=0/1)

| Bit   | Name           | Access | Description                          | Reset<br>value |
|-------|----------------|--------|--------------------------------------|----------------|
| [7:0] | R8_SPIx_BUFFER | RW     | SPI data transmit and receive buffer | XX             |

## SPI working status register (R8\_SPIx\_RUN\_FLAG) (x=0/1)

| Bit | Name              | Access | Description                                                                                           | Reset<br>value |
|-----|-------------------|--------|-------------------------------------------------------------------------------------------------------|----------------|
| 7   | RB_SPI_SLV_SELECT | RO     | <ul><li>SPI0 slave mode selection status bit:</li><li>1: Device mode;</li><li>0: Host mode.</li></ul> | 0              |

|       |                    |    | Note: Not supported by SPI1                                                                                                                                                                                                                      |   |
|-------|--------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 6     | RB_SPI_SLV_CS_LOAD | RO | After SPI0 slave mode chip selection, first<br>load status bit:<br>1: Loading is completed;<br>0: Not completed (the preload value can be<br>modified).<br>Note: Not supported by SPI1                                                           | 0 |
| 5     | RB_SPI_FIFO_READY  | RO | <ul><li>FIFO ready status bit:</li><li>1: FIFO is ready;</li><li>0: FIFO is not ready.</li></ul>                                                                                                                                                 | 0 |
| 4     | RB_SPI_SLV_CMD_ACT | RO | Command receive completion status bit in<br>SPI0 slave mode, namely to completing the<br>exchange of first-byte data:<br>1: The first byte exchange is completed;<br>1: The first byte exchange is not completed.<br>Note: Not supported by SPI1 | 0 |
| [3:0] | Reserved           | RO | Reserved.                                                                                                                                                                                                                                        | 0 |

## SPI interrupt flag register (R8\_SPIx\_INT\_FLAG) (x=0/1)

| Bit | Name               | Access | Description                                      | Reset<br>value |
|-----|--------------------|--------|--------------------------------------------------|----------------|
|     |                    |        | First byte receive flag bit in SPI0 device mode: |                |
| 7   | RB SPI IF FST BYTE | RW1    | 1: The first byte is received;                   | 0              |
| ,   |                    |        | 0: The first byte is not received.               | Ū              |
|     |                    |        | Note: Not supported by SPI1.                     |                |
|     |                    |        | Current SPI idle status bit:                     |                |
| 6   | RB SPI FREE        | RO     | 1: SPI is currently in idle state;               | 0              |
|     |                    |        | 0: SPI is currently in non-idle state.           |                |
| 5   | Reserved           | RO     | Reserved.                                        | 0              |
|     |                    |        | SPI0 FIFO overflow flag bit, only supported      |                |
|     |                    |        | by SPI0:                                         |                |
| 4   | RB_SPI_IF_FIFO_OV  | RW1    | 1: FIFO overflow;                                | 0              |
|     |                    |        | 0: FIFO not overflow.                            |                |
|     |                    |        | Note: Not supported by SPI1.                     |                |
|     |                    |        | SPI0 DMA end flag bit, only supported by         |                |
|     |                    |        | SPI0:                                            |                |
| 3   | RB_SPI_IF_DMA_END  | RW1    | 1: DMA transmission is ended;                    | 0              |
|     |                    |        | 0: DMA transmission is not ended.                |                |
|     |                    |        | Note: Not supported by SPI1.                     |                |
|     |                    |        | FIFO data more than half flag bit:               |                |
|     |                    |        | 1: Data reaches half of the FIFO buffer;         |                |
|     |                    |        | 0: Data does not reach half of the FIFO buffer;  |                |
| 2   | RB_SPI_IF_FIFO_HF  | RW1    | Note: If RB_SPI_FIFO_DIR=1, receive data,        | 0              |
|     |                    |        | trigger when FIFO count $\geq 4$ ;               |                |
|     |                    |        | If RB_SPI_FIFO_DIR=0, transmit data,             |                |
|     |                    |        | trigger when FIFO count <4.                      |                |
| 1   | RB SPI IF BYTE END | RW1    | SPI single byte transmission completion flag     | 0              |
|     |                    | 11     | bit:                                             | v              |

|   |                   |     | <ol> <li>SPI single byte transmission is completed;</li> <li>SPI single byte transmission is not completed.</li> </ol>                                                     |   |
|---|-------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 0 | RB_SPI_IF_CNT_END | RW1 | <ul><li>SPI all byte transmission completion flag bit:</li><li>1: SPI all byte transmission is completed;</li><li>0: SPI all byte transmission is not completed.</li></ul> | 0 |

## SPI transceiver FIFO count register (R8\_SPIx\_FIFO\_COUNT) (x=0/1)

| Bit   | Name               | Access | Description                         | Reset<br>value |
|-------|--------------------|--------|-------------------------------------|----------------|
| [7:0] | R8_SPIx_FIFO_COUNT | RW     | Count of bytes in the current FIFO. | XX             |

## SPI transceiver FIFO count register (R8\_SPIx\_FIFO\_COUNT1) (x=0/1)

| Bit   | Name                | Access | Description                                                                                    | Reset<br>value |
|-------|---------------------|--------|------------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_SPIx_FIFO_COUNT1 | RW     | Count of bytes in the current FIFO, it is<br>equivalent to the register<br>R8_SPIx_FIFO_COUNT. | xx             |

#### SPI transceiver data total length register (R16\_SPIx\_TOTAL\_CNT) (x=0/1)

| Bit    | Name               | Access | Description                                                                                                                                                              | Reset<br>value |
|--------|--------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | R16_SPIx_TOTAL_CNT | RW     | The total number of bytes of SPI data<br>receiver and transmit, and the lower 12 bits<br>are valid. At most 4095 bytes can be<br>transmitted at a time when DMA is used. | 0              |

## SPI FIFO register (R8\_SPIx\_FIFO) (x=0/1)

| Bit   | Name         | Access    | Description                                  | Reset<br>value |
|-------|--------------|-----------|----------------------------------------------|----------------|
| [7:0] | R8_SPIx_FIFO | RO/<br>WO | SPI FIFO register. The FIFO size is 8 bytes. | 0              |

Register R8\_SPIx\_BUFFER and register R8\_SPIx\_FIFO are SPI data related registers. The main difference is: after the latter reads one byte of data, as it reads from FIFO, the value of length register (R16\_SPI\_TOTAL\_CNT) is automatically reduced by 1; after the former reads one byte, the value of length register remains unchanged.

## Current address of SPI0 DMA buffer (R16\_SPI0\_DMA\_NOW)

| Bit    | Name             | Access | Description                                                                                                             | Reset<br>value |
|--------|------------------|--------|-------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | R16_SPI0_DMA_NOW | RW     | Current address of DMA buffer, only<br>supported by SPI0.<br>The DMA operation can be judged by<br>querying this value. | xxxx           |

Start address of SPI0 DMA buffer (R16\_SPI0\_DMA\_BEG)

| Bit | Name | Access | Description | Reset |
|-----|------|--------|-------------|-------|
|     |      |        |             |       |

|        |                  |    |                                                                                                                                    | value |
|--------|------------------|----|------------------------------------------------------------------------------------------------------------------------------------|-------|
| [15:0] | R16_SPI0_DMA_BEG | RW | Start address of DMA buffer, only supported<br>by SPI0.<br>Point to the start address of SPI0 receive and<br>transmit data buffer. | xxxx  |

End address of SPI0 DMA buffer (R16 SPI0 DMA END)

| Bit    | Name             | Access | Description                                                                                                                    | Reset<br>value |
|--------|------------------|--------|--------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | R16_SPI0_DMA_END | RW     | End address of DMA buffer, only supported<br>by SPI0.<br>Point to the end address of SPI0 receive and<br>transmit data buffer. | xxxx           |

## **6.3 SPI Transmission Format**

SPI supports two transmission formats, mode 0 and mode 3, which can be selected by setting RB\_SPI\_MST\_SCK\_MOD bit of SPI mode configuration register (R8\_SPIx\_CTRL\_MOD).

The data transmission format is shown in the figure below:

Mode 0: RB\_SPI\_MST\_SCK\_MOD = 0

#### 模式0时序图



Figure 6-1 Transmission Format of SPI Mode 0

| Mode 3: RB | SPI | MST | SCK | MOD = | 1 |
|------------|-----|-----|-----|-------|---|
|            |     |     |     |       |   |

模式3时序图



Figure 6-2 Transmission Format of SPI Mode 3

## **6.4 SPI Configuration**

## 6.4.1 SPI Master Mode

In SPI master mode, serial clock is generated on SCK pin, and the chip selection pin can be specified as any I/O pin.

Configuration Steps:

(1). Set SPI master mode clock divider register (R8\_SPIx\_CLOCK\_DIV), to configure SPI clock Relevant information can be downloaded from the website: <a href="https://www.wch.cn">www.wch.cn</a>

speed;

(2). Set the RB\_SPI\_MODE\_SLAVE bit of SPI mode configuration register (R8\_SPIx\_CTRL\_MOD) to 0, to configure SPI as the master mode;

(3). Set the RB\_SPI\_SLV\_CMD\_MOD bit of SPI mode configuration register (R8\_SPIx\_CTRL\_MOD), and set it to mode 0 or mode 3 according to the requirements of the connected device;

(4). Set the RB\_SPI\_FIFO\_DIR bit of SPI mode configuration register (R8\_SPIx\_CTRL\_MOD), to configure the FIFO direction. If it is 1, the current FIFO direction is data input; if it is 0, the current FIFO direction is data output.

(5). Set the RB\_SPI\_MOSI\_OE bit and RB\_SPI\_SCK\_OE bit of SPI mode configuration register (R8\_SPIx\_CTRL\_MOD) to 1, and set the RB\_SPI\_MISO\_OE bit to 0, and set the bits corresponding to the MOSI pin and SCK pin in the PA port direction register (R32\_PB\_DIR) to 1, the bit corresponding to MISO pin to 0, to configure the MOSI pin and SCK pin direction as output, and configure the MISO pin direction as input;

Data transmit process:

(1). Set the RB\_SPI\_FIFO\_DIR bit of SPI mode configuration register (R8\_SPIx\_CTRL\_MOD) to 0, to configure the current FIFO direction as output;

(2). Write R16\_SPIx\_TOTAL\_CNT register, to set the length of the data to be transmitted;

(3). Write R8\_SPIx\_FIFO register, write the data to be transmitted to FIFO. If R8\_SPI0\_FIFO\_COUNT is less than FIFO size, data can continue to be written to FIFO;

(4). After all data is written to FIFO, wait until R16\_SPIx\_TOTAL\_CNT register becomes 0, it indicates that the data transmission is completed. If only one-byte data is transmitted, you can also wait until R8\_SPI0\_FIFO\_COUNT becomes 0, it indicates that there is no data in FIFO and the data transmission is completed.

Data receive process:

(1). Set the RB\_SPI\_FIFO\_DIR bit of SPI mode configuration register (R8\_SPIx\_CTRL\_MOD) to 1, to configure the current FIFO direction as input;

(2). Write R16 SPIx TOTAL CNT register, to set the length of the data to be received;

(3). Wait until R8\_SPIx\_FIFO\_COUNT register is not 0, it indicates that the returned data is received;

(4). The value read in R8\_SPIx\_FIFO is the received data.

#### 6.4.2 SPI Slave Mode

Only SPI0 supports the slave mode. In the slave mode, SCK pin is used to receive the serial clock of the connected SPI host.

Configuration Steps:

(1). Set the RB\_SPI\_MODE\_SLAVE bit of SPI0 mode configuration register (R8\_SPI0\_CTRL\_MOD) to 1, to configure SPI0 as the slave mode;

(2). Set the RB\_SPI\_SLV\_CMD\_MOD bit of SPI0 mode configuration register (R8 SPI0 CTRL MOD) as required;

(3). Set the RB\_SPI\_FIFO\_DIR bit of SPI0 mode configuration register (R8\_SPI0\_CTRL\_MOD), to configure the FIFO direction. If it is 1, the current FIFO direction is data input. If it is 0, the current FIFO direction is data output.

(4). Set the RB\_SPI\_MOSI\_OE bit and RB\_SPI\_SCK\_OE bit of SPI0 mode configuration register (R8\_SPI0\_CTRL\_MOD) to 0, set the RB\_SPI\_MISO\_OE bit to 1, and set the bits corresponding to the MOSI pin, SCK pin and SCS pin in the PA port direction register (R32\_PB\_DIR) to 0, set the bit corresponding to MISO pin to 1, to configure the MOSI pin, SCK pin and SCS pin direction as input, and configure the MISO pin direction as output. If the MISO pin is not configured as output, when chip selection is valid (low level), MISO will automatically enable output. It is recommended to set the MISO pin as input

so that MISO does not output when chip selection is invalid, so that SPI bus can be shared when multiple devices work. Note: In SPI slave mode, I/O pin direction of MISO can be configured as output by the MISO pin direction, it can also be configured as output automatically during the valid SPI chip selection, but its output data is selected by RB\_SPI\_MISO\_OE. When RB\_SPI\_MISO\_OE is 1, output SPI data. When RB SPI MISO OE is 0, output data of GPIO register.

(5). Optionally, set the preset data register in SPI0 slave mode (R8\_SPI0\_SLAVE\_PRE), to be automatically loaded into the buffer for the first time after chip selection for external output. After 8 clocks (that is, the first byte of data exchange between the host and the slave is completed), the controller will obtain the first byte of data (command code) sent by the external SPI host, and the external SPI host obtains the preset data in R8\_SPI0\_SLAVE\_PRE (status value) through exchange. The bit 7 of this register will be automatically loaded into the MISO pin during low-level SCK after the SPI chip selection is effective. For SPI mode 0 (CLK defaults to low level), if the bit 7 of R8\_SPI0\_SLAVE\_PRE is preset, the external SPI master will obtain the preset value of bit 7 of R8\_SPI0\_SLAVE\_PRE by inquiring the MISO pins when the SPI chip selection is effective but has no data transmission, thereby the value of bit 7 of R8\_SPI0\_SLAVE\_PRE can be obtained only by validating SPI chip selection.

Data transmit process:

(1). Set the RB\_SPI\_FIFO\_DIR bit of SPI mode configuration register (R8\_SPIx\_CTRL\_MOD) to 0, to configure FIFO direction as data output;

(2) Write the data to be transmitted to FIFO register (R8\_SPIx\_FIFO), and add 1 to the SPI transmit/receive data total length register (R16\_SPIx\_TOTAL\_CNT). It is recommended to set R16\_SPIx\_TOTAL\_CNT to a larger value directly. In this way, once there is data in FIFO, it will be transmitted automatically, and it will be automatically suspended when the FIFO is empty. It is not necessary to set R16\_SPIx\_TOTAL\_CNT every time;

(3). If a single byte is sent, wait for the R16\_SPIx\_TOTAL\_CNT register to be 0, and wait for all data to be sent. If multiple bytes are sent, you can write up to 8 data to the FIFO register (R8\_SPIx\_FIFO) at a time, and then wait for completing sending;

Data receive process:

(1). Set the RB\_SPI\_FIFO\_DIR bit of SPI mode configuration register (R8\_SPIx\_CTRL\_MOD) to 1, to configure the current FIFO direction as data input;

(2) Wait to query the SPI transmit/receive data total length register (R16\_SPIx\_TOTAL\_CNT). If the register is not 0, data is received, and the received data can be obtained by reading the FIFO register (R8\_SPIx\_FIFO).

For receiving the data of single byte, FIFO is not required, and SPI data buffer register (R8\_SPIx\_BUFFER) can be read directly to obtain the current data given by the other party for starting transmission.

## 6.5 DMA Function

For CH567, only SPI0 has DMA function, but SPI1 does not have this function. By enabling the DMA function, receiving and transmiting SPI data can be realized more conveniently on the basis of reducing software intervention.

#### 6.5.1 DMA Transmiting Data Configuration in SPI Master Mode

(1). According to Section 6.4.1, configure SPI0 as master mode;

(2). If it is needed to generate a DMA completion interrupt, set the RB\_SPI\_IE\_DMA\_END bit of SPI interrupt enable register (R8 SPIx INTER EN) to 1;

(3). Initialize the R16 SPI DMA BEG register as the start address of SPI data transmit buffer;

(4). Initialize the R16 SPI DMA END register as the end address of SPI data transmit buffer;

(5). Clear SPI interrupt status register (R8\_SPIx\_INT\_FLAG);

(6). Initialize the R16\_SPI\_TOTAL\_CNT register to the number of data to be sent, and start the transmission if DMA is enabled;

(7). If it is needed to enable the DMA address loop mode function, set the RB\_SPI\_DMA\_LOOP bit of SPI DMA control register (R8 SPIx CTRL DMA) to 1;

(8). Set the RB\_SPI\_DMA\_ENABLE bit of DMA control register (R8\_SPIx\_CTRL\_DMA) of SPI to 1, to enable DMA to transmit data.

#### 6.5.2 DMA Receiving Data Configuration in SPI Master Mode

(1). According to Section 6.4.1, configure SPI0 as master mode;

(2). If it is needed to generate DMA interrupt, set the RB\_SPI\_IE\_DMA\_END bit of register R8\_SPI\_INTER\_EN to 1, to enable generating the DMA end interrupt;

(3). Initialize the R16\_SPI\_DMA\_BEG register as the start address of SPI data receive buffer;

(4). Initialize the R16 SPI DMA END register as the end address of SPI data receive buffer;

(5). Clear SPI interrupt status register (R8\_SPIx\_INT\_FLAG);

(6). Initialize the R16\_SPI\_TOTAL\_CNT register to the number of data to be received, and start the transmission if DMA is enabled;

(7). If it is needed to enable the DMA address loop mode function, set the RB\_SPI\_DMA\_LOOP bit of SPI DMA control register (R8 SPIx CTRL DMA) to 1;

(8). Set the RB\_SPI\_DMA\_ENABLE bit of DMA control register (R8\_SPIx\_CTRL\_DMA) of SPI to 1, and enable DMA to receive data. If DMA is enabled first, transmission will start automatically after R16\_SPI\_TOTAL\_CNT is set.

# Chapter 7 Universal Asynchronous Receiver-Transmitter (UART)

## 7.1 Introduction to UART

CH567 is equipped with 4 sets of full-duplex asynchronous serial ports, UART0/1/2/3, and they support full-duplex and half-duplex serial communication. Among them, UART0 is equipped with a transmit status pin for switching RS485, and supports MODEM signals CTS, DSR, RI, DCD, DTR and RTS.

UART features:

(1). Compatible with 16C550 asynchronous serial port and enhanced;

(2). Support 5, 6, 7 or 8 data bits and 1 or 2 stop bits;

(3). Support the parity check modes of odd, even, no check, blank 0 and flag 1;

(4). Programmable communication baud rate, support 115200bps and communication baud rate up to 6Mbps;

(5). Built-in 8-byte FIFO (first-in-first-out) buffer, support 4 FIFO trigger levels;

(6). UART0 supports MODEM modem signals CTS, DSR, RI, DCD, DTR and RTS, which can be converted to RS232 level;

(7). Support automatic handshake and automatic transmission rate control of hardware flow control signals CTS and RTS, compatible with TL16C550C;

(8). Support serial port frame error detection and Break line interval detection;

(9). Support full-duplex and half-duplex serial communication, and UART0 provides a transmit status pin for switching RS485;

### 7.2 Register Description

UART0 related register physical start address: 0x0040 3000

UART1 related register physical start address: 0x0040 3400

UART2 related register physical start address: 0x0040 3800

UART3 related register physical start address: 0x0040 3c00

| Name         | Offset address | Description                     | Reset value |
|--------------|----------------|---------------------------------|-------------|
| R8_UART0_MCR | 0x00           | MODEM control register          | 8h00        |
| R8_UART0_IER | 0x01           | Interrupt enable register       | 8h00        |
| R8_UART0_FCR | 0x02           | FIFO control register           | 8h00        |
| R8_UART0_LCR | 0x03           | Line control register           | 8h00        |
| R8_UART0_IIR | 0x04           | Interrupt recognition register  | 8h01        |
| R8_UART0_LSR | 0x05           | Line status register            | 8hC0        |
| R8_UART0_MSR | 0x06           | MODEM status register           | 8hx0        |
| R8_UART0_RBR | 0x08           | Receive buffer register         | 8hxx        |
| R8_UART0_THR | 0x08           | Transmit hold register          | 8hxx        |
| R8_UART0_RFC | 0x0A           | Receiver FIFO count register    | 8hxx        |
| R8_UART0_TFC | 0x0B           | Transmitter FIFO count register | 8hxx        |
| R16_UART0_DL | 0x0C           | Baud rate divisor latch         | 16hxxxx     |
| R8_UART0_DIV | 0x0E           | Predivider divisor register     | 8hxx        |
| R8_UART0_ADR | 0x0F           | Slave address register          | 8hFF        |

Table 7-1 List of UART0 Related Registers

#### Table 7-2 List of UART1 Related Registers

| Name | Offset address | Description | Reset value |
|------|----------------|-------------|-------------|
|      |                |             |             |

| R8_UART1_MCR | 0x00 | MODEM control register          | 8h00    |
|--------------|------|---------------------------------|---------|
| R8_UART1_IER | 0x01 | Interrupt enable register       | 8h00    |
| R8_UART1_FCR | 0x02 | FIFO control register           | 8h00    |
| R8_UART1_LCR | 0x03 | Line control register           | 8h00    |
| R8_UART1_IIR | 0x04 | Interrupt recognition register  | 8h01    |
| R8_UART1_LSR | 0x05 | Line status register            | 8hC0    |
| R8_UART1_RBR | 0x08 | Receive buffer register         | 8hxx    |
| R8_UART1_THR | 0x08 | Transmit hold register          | 8hxx    |
| R8_UART1_RFC | 0x0A | Receiver FIFO count register    | 8hxx    |
| R8_UART1_TFC | 0x0B | Transmitter FIFO count register | 8hxx    |
| R16_UART1_DL | 0x0C | Baud rate divisor latch         | 16hxxxx |
| R8_UART1_DIV | 0x0E | Predivider divisor register     | 8hxx    |

#### Table 7-3 List of UART2 Related Registers

| Name         | Offset address | Description                     | Reset value |
|--------------|----------------|---------------------------------|-------------|
| R8_UART2_MCR | 0x00           | MODEM control register          | 8h00        |
| R8_UART2_IER | 0x01           | Interrupt enable register       | 8h00        |
| R8_UART2_FCR | 0x02           | FIFO control register           | 8h00        |
| R8_UART2_LCR | 0x03           | Line control register           | 8h00        |
| R8_UART2_IIR | 0x04           | Interrupt recognition register  | 8h01        |
| R8_UART2_LSR | 0x05           | Line status register            | 8hC0        |
| R8_UART2_RBR | 0x08           | Receive buffer register         | 8hxx        |
| R8_UART2_THR | 0x08           | Transmit hold register          | 8hxx        |
| R8_UART2_RFC | 0x0A           | Receiver FIFO count register    | 8hxx        |
| R8_UART2_TFC | 0x0B           | Transmitter FIFO count register | 8hxx        |
| R16_UART2_DL | 0x0C           | Baud rate divisor latch         | 16hxxxx     |
| R8_UART2_DIV | 0x0E           | Predivider divisor register     | 8hxx        |

#### Table 7-4 List of UART3 Related Registers

| Name         | Offset address | Description                     | Reset value |
|--------------|----------------|---------------------------------|-------------|
| R8_UART3_MCR | 0x00           | MODEM control register          | 8h00        |
| R8_UART3_IER | 0x01           | Interrupt enable register       | 8h00        |
| R8_UART3_FCR | 0x02           | FIFO control register           | 8h00        |
| R8_UART3_LCR | 0x03           | Line control register           | 8h00        |
| R8_UART3_IIR | 0x04           | Interrupt recognition register  | 8h01        |
| R8_UART3_LSR | 0x05           | Line status register            | 8hC0        |
| R8_UART3_RBR | 0x08           | Receive buffer register         | 8hxx        |
| R8_UART3_THR | 0x08           | Transmit hold register          | 8hxx        |
| R8_UART3_RFC | 0x0A           | Receiver FIFO count register    | 8hxx        |
| R8_UART3_TFC | 0x0B           | Transmitter FIFO count register | 8hxx        |
| R16_UART3_DL | 0x0C           | Baud rate divisor latch         | 16hxxxx     |
| R8_UART3_DIV | 0x0E           | Predivider divisor register     | 8hxx        |

# Modulator-demodulator (MODEM) control register (R8\_UARTx\_MCR) (x=0/1/2/3)

| Bit | Name        | Access | Description                             | Reset<br>value |
|-----|-------------|--------|-----------------------------------------|----------------|
| 7   | RB_MCR_HALF | RW     | UART0 half-duplex receive/transmit mode | 0              |

| <b></b> |                   |     | · · · · · · · · · · · · · · · · · · ·              | i |
|---------|-------------------|-----|----------------------------------------------------|---|
|         |                   |     | enable/disable bit                                 |   |
|         |                   |     | 1: Enter half-duplex receive/transmit mode,        |   |
|         |                   |     | giving priority to transmission, receiving         |   |
|         |                   |     | when not transmitting;                             |   |
|         |                   |     | 0: Disable half-duplex receive/transmit mode.      |   |
|         |                   |     | Note: Only UART0 supports.                         |   |
| l       |                   |     | Being transmitting status (TNOW) output            |   |
|         |                   |     | (DTR pin) enable bit of UART0:                     |   |
|         |                   |     | 1: Enable the DTR pin of UART0 to output           |   |
|         |                   | DIV | the status of being transmitting TNOW, which       | 0 |
| 6       | RB_MCR_TNOW       | RW  | can be used to control RS485 receive/transmit      | 0 |
|         |                   |     | switching;                                         |   |
|         |                   |     | 0: Disable.                                        |   |
|         |                   |     | Note: Only UART0 supports.                         |   |
|         |                   |     | UARTO allow CTS and RTS hardware                   |   |
|         |                   |     | automatic flow control bit:                        |   |
|         |                   |     | 1: Allow CTS and RTS hardware automatic            |   |
|         |                   |     | flow control;                                      |   |
|         |                   |     | 0: Invalid.                                        |   |
|         |                   |     | Note: Only UART0 supports.                         |   |
|         |                   |     | In the flow control mode, if this bit is 1, then   |   |
|         |                   |     |                                                    |   |
|         |                   |     | UART will continuously send the next data          |   |
|         |                   |     | only when it detects that the CTS pin input is     |   |
|         |                   |     | valid (active low). Otherwise, UART will           |   |
| _       |                   |     | suspend transmission. And CTS input status         | 0 |
| 5       | RB_MCR_AU_FLOW_EN | RW  | change will not generate MODEM status              | 0 |
|         |                   |     | interrupt when this bit is 1. If this bit is 1 and |   |
|         |                   |     | RTS is 1, UART will automatically validate         |   |
|         |                   |     | the RTS pin (active low) when receiver FIFO        |   |
|         |                   |     | is empty. UART will automatically invalidate       |   |
|         |                   |     | the RTS pin when the number of received            |   |
|         |                   |     | bytes reaches the trigger point of FIFO and        |   |
|         |                   |     | will re-validate the RTS pin when the receiver     |   |
|         |                   |     | FIFO is empty. The CTS pin can be                  |   |
|         |                   |     | connected to another RTS pin through the           |   |
|         |                   |     | hardware automatic band rate control, and the      |   |
|         |                   |     | RTS pin can be connected to another CTS pin.       |   |
|         |                   |     | Test mode control bit of UART0 internal            |   |
|         |                   |     | loop:                                              |   |
|         |                   |     | 1: Enable the test mode of internal loop;          |   |
|         |                   |     | 0: Disable the test mode of internal loop.         |   |
|         |                   |     | In the test mode of the internal loop, all output  |   |
|         |                   |     | pins of UART are invalid, TXD internally           |   |
| 4       | RB_MCR_LOOP       | RW  | returns to RXD (i.e., the output of TSR            | 0 |
|         |                   |     | internally returns to the input of RSR), RTS       |   |
|         |                   |     | internally returns to CTS, DTR internally          |   |
|         |                   |     |                                                    |   |
|         |                   |     | returns to DSR, OUT1 internal returns to RI        |   |
|         |                   |     | and OUT2 internally returns to DCD                 |   |
|         |                   |     | Note: Only UART0 supports.                         |   |

| 3 | RB_MCR_OUT2 | RW | UART interrupt request output control bit:<br>1: Enable;<br>0: Disable.                                                                                                                 | 0 |
|---|-------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 2 | RB_MCR_OUT1 | RW | User-defined MODEM control bit, and no<br>actual output pin is connected:<br>1: Set to high level;<br>0: Set to low level.<br>Note: Only UART0 supports.                                | 0 |
| 1 | RB_MCR_RTS  | RW | <ul> <li>RTS pin output valid control bit:</li> <li>0: Enable RTS pin output valid (active low)</li> <li>0: Disable RTS pin output valid</li> <li>Note: Only UART0 supports.</li> </ul> | 0 |
| 0 | RB_MCR_DTR  | RW | DTR pin output valid control bit:<br>1: Enable pin output valid (active low);<br>0: Disable pin output valid.<br>Note: Only UART0 supports.                                             | 0 |

# Interrupt enable register (R8\_UARTx\_IER) (x=0/1/2/3)

| Bit | Name             | Access | Description                                                                                                                                                                    | Reset<br>value |
|-----|------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | RB_IER_RESET     | WZ     | <ul><li>UART software reset control bit, cleared<br/>automatically:</li><li>1: Software resets UART;</li><li>0: Do not perform software reset.</li></ul>                       | 0              |
| 6   | RB_IER_TXD_EN    | RW     | UART TXD pin output enable bit:<br>1: Enable pin output;<br>0: Disable pin output.                                                                                             | 0              |
| 5   | RB_IER_RTS_EN    | RW     | <ul><li>RTS pin output enable bit of UART0:</li><li>1: Enable pin output;</li><li>0: Disable pin output.</li><li>Note: Only UART0 supports.</li></ul>                          | 0              |
| 4   | RB_IER_DTR_EN    | RW     | DTR/TNOW pin output enable bit of<br>UART0:<br>1: Enable pin output;<br>0: Disable pin output.<br>Note: Only UART0 supports.                                                   | 0              |
| 3   | RB_IER_MODEM_CHG | RW     | Modem input status change interrupt enable<br>bit of UART0:<br>1: Enable the corresponding interrupt;<br>0: Disable the corresponding interrupt.<br>Note: Only UART0 supports. | 0              |
| 2   | RB_IER_LINE_STAT | RW     | Receive line status interrupt enable bit:<br>1: Enable the corresponding interrupt;<br>0: Disable the corresponding interrupt.                                                 | 0              |
| 1   | RB_IER_THR_EMPTY | RW     | <ul><li>Transmit hold register empty interrupt enable</li><li>bit:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>    | 0              |
| 0   | RB_IER_RECV_RDY  | RW     | Receive data interrupt enable bit:                                                                                                                                             | 0              |

|  |  | 1: Enable the corresponding interrupt;  |  |
|--|--|-----------------------------------------|--|
|  |  | 0: Disable the corresponding interrupt. |  |

### FIFO control register (R8\_UARTx\_FCR) (x=0/1/2/3)

| Bit   | Name               | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset<br>value |
|-------|--------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:6] | RB_FCR_FIFO_TRIG   | RW     | Interrupt and hardware flow control trigger<br>point set domain of receiver FIFO:<br>00: 1 byte;<br>01: 2 bytes;<br>10: 4 bytes;<br>11: 7 bytes.<br>This domain is used to set the interrupt and<br>hardware flow control trigger point of<br>receiver FIFO. For example: 00 corresponds<br>to 1 byte, that is, interrupt available for<br>receiving data is generated when 1 byte is<br>received, and RTS pin is automatically<br>invalidated when hardware flow control is<br>enabled. | 0              |
| [5:3] | Reserved           | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0              |
| 2     | RB_FCR_TX_FIFO_CLR | WZ     | Transmitter FIFO data clear enable bit,<br>cleared automatically:<br>1: Clear the data of transmitter FIFO<br>(excluding TSR);<br>0: Not clear the data of transmitter FIFO.                                                                                                                                                                                                                                                                                                             | 0              |
| 1     | RB_FCR_RX_FIFO_CLR | WZ     | Receiver FIFO data clear enable bit, cleared<br>automatically:<br>1: Clear the data of receiver FIFO (excluding<br>RSR);<br>0: Not clear the data of receiver FIFO.                                                                                                                                                                                                                                                                                                                      | 0              |
| 0     | RB_FCR_FIFO_EN     | RW     | <ul> <li>FIFO enable bit:</li> <li>1: Enable FIFO, internal FIFO size is 8 bytes;</li> <li>0: Disable FIFO.</li> <li>After disabling FIFO, it is 16C450</li> <li>compatible mode, which means that there is</li> <li>only one byte in FIFO (RECV_TG1=0,</li> <li>RECV_TG0=0, FIFO_EN=1), and it is</li> <li>recommended to enable FIFO.</li> </ul>                                                                                                                                       | 0              |

# Line control register (R8\_UARTx\_LCR) (x=0/1/2/3)

| Bit | Name                          | Access | Description                                                                                                                                 | Reset<br>value |
|-----|-------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | RB_LCR_DLAB/<br>RB_LCR_GP_BIT | RW     | UART common bit (user-defined).                                                                                                             | 0              |
| 6   | RB_LCR_BREAK_EN               | RW     | Forced to generate BREAK line interval<br>enable bit:<br>1: Forced to generate BREAK line interval.<br>0: Not generate BREAK line interval. | 0              |

| [5:4] | RB_LCR_PAR_MOD  | RW | Parity check bit format set domain<br>00: Odd check;<br>01: Even check;<br>10: Flag bit (MARK, set to 1);<br>11: Space bit (SPACE, cleared).<br>This domain is valid only when<br>RB_LCR_PAR_EN bit is 1. | 0 |
|-------|-----------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 3     | RB_LCR_PAR_EN   | RW | Parity bit enable bit:<br>1: Allow to generate parity bit when<br>transmitting and check parity bit when<br>receiving;<br>0: No parity bit.                                                               | 0 |
| 2     | RB_LCR_STOP_BIT | RW | Stop bit format set bit:0: One stop bit;1: Two stop bits.                                                                                                                                                 | 0 |
| [1:0] | RB_LCR_WORD_SZ  | RW | UART data length set domain:<br>00: 5 data bits;<br>01: 6 data bits;<br>10: 7 data bits;<br>11: 8 data bits.                                                                                              | 0 |

#### Interrupt identification register (R8\_UARTx\_IIR) (x=0/1/2/3)

| Bit   | Name            | Access | Description                                                                                                                                                                                     | Reset<br>value |
|-------|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:6] | RB_IIR_FIFO_ID  | RO     | UART FIFO enable status bit:<br>1: FIFO is enabled;<br>0: FIFO is not enabled.                                                                                                                  | 0              |
| [5:4] | Reserved        | RO     | Reserved.                                                                                                                                                                                       | 0              |
| [3:0] | RB_IIR_INT_MASK | RO     | Interrupt flag domain: If RB_IIR_NO_INT<br>bit is 0, an interrupt is generated, and it is<br>needed to judge the interrupt source by<br>reading this domain. See the table below for<br>details | 0              |
| 0     | RB_IIR_NO_INT   | RO     | UART no interrupt flag bit:<br>1: No interrupt;<br>0: Interrupt.                                                                                                                                | 1              |

The meaning of bit RB\_IIR\_NO\_INT of interrupt recognition register (R8\_UARTx\_IIR) and each bit of RB\_IIR\_INT\_MASK domain are shown in the following table:

### Table 8-3 Meaning of RB\_IIR\_INT\_MASK in IIR Register

|   | IR re<br>IID2 | 0 | · bit<br>NOINT | Precedence<br>level | Interrupt Type            | Interrupt sources | Clearing<br>interrupt<br>Method |
|---|---------------|---|----------------|---------------------|---------------------------|-------------------|---------------------------------|
| 0 | 0             | 0 | 1              | None                | No interrupt<br>generated | No interrupt      |                                 |

| 1 | 1 | 1 | 0 | 0 | Bus address<br>matching   | preset slave value or the broadcast address.                                                       | Read IIR or<br>disable<br>multi-device<br>mode |
|---|---|---|---|---|---------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------|
| 0 | 1 | 1 | 0 | 1 | Receive line<br>status    | OVER_ERR, PAR_ERR,<br>FRAM_ERR, BREAK_ERR                                                          | Read LSR                                       |
| 0 | 1 | 0 | 0 | 2 | Receive data<br>available | The number of bytes received reaches the trigger point of FIFO.                                    | Read RBR                                       |
| 1 | 1 | 0 | 0 | 2 | Receive data<br>timeout   | No next data is received when the time of four data is exceeded.                                   | Read RBR                                       |
| 0 | 0 | 1 | 0 | 3 | THR register<br>empty     | Transmit hold register empty, or<br>RB_IER_THR_EMPTY bit is changed<br>from 0 to 1 for triggering. | Read IIR or<br>write THR                       |
| 0 | 0 | 0 | 0 | 4 | MODEM input change        | Trigger by setting $\triangle$ CTS, $\triangle$ DSR, $\triangle$ RI and $\triangle$ DCD to 1.      | Read MSR                                       |

# Line status register (R8\_UARTx\_LSR) (x=0/1/2/3)

| Bit | Name               | Access | Description                                                                                                                                                                                 | Reset<br>value |
|-----|--------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | RB_LSR_ERR_RX_FIFO | RO     | Receiver FIFO error flag bit:<br>1: There is at least one PAR_ERR or<br>FRAM_ERR or BREAK_ERR error in the<br>receiver FIFO;<br>0: There is no error in receiver FIFO.                      | 0              |
| 6   | RB_LSR_TX_ALL_EMP  | RO     | <ul><li>Transmit hold register THR and transmit shift register TSR empty flag.</li><li>1: Both of them are empty;</li><li>0: Both of them are not empty.</li></ul>                          | 1              |
| 5   | RB_LSR_TX_FIFO_EMP | RO     | Transmitter FIFO empty flag bit:<br>1: Transmitter FIFO is empty;<br>0: Transmitter FIFO is not empty.                                                                                      | 1              |
| 4   | RB_LSR_BREAK_ERR   | RZ     | <ul><li>BREAK line interval detection flag bit:</li><li>1: BREAK line interval is detected:</li><li>0: BREAK line interval is not detected:</li></ul>                                       | 0              |
| 3   | RB_LSR_FRAME_ERR   | RZ     | Data frame error flag bit:<br>1: It means the frame error of the data being<br>read from the receiver FIFO due to lack of a<br>valid stop bit;<br>0: The data frame is correct.             | 0              |
| 2   | RB_LSR_PAR_ERR     | RZ     | <ul><li>Parity error flag bit of received data:</li><li>1: It means that there is parity error of the data being read from the receiver FIFO;</li><li>0: Parity check is correct.</li></ul> | 0              |
| 1   | RB_LSR_OVER_ERR    | RZ     | Receiver FIFO buffer overflow flag bit:<br>1: Overflowed;<br>0: Not overflowed.                                                                                                             | 0              |
| 0   | RB_LSR_DATA_RDY    | RO     | Flag bit of data received in receiver FIFO:                                                                                                                                                 | 0              |

|  | 1: There is data in FIFO;                                   |  |
|--|-------------------------------------------------------------|--|
|  | 0: No data.<br>After reading all data in the FIFO, this bit |  |
|  | will be automatically cleared.                              |  |

### Modulator-demodulator (MODEM) status register (R8\_UART0\_MSR) (only supported by UART0)

| Bit | Name           | Access | Description                                                                                                                        | Reset<br>value |
|-----|----------------|--------|------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | RB_MSR_DCD     | RO     | DCD pin status bit:<br>1: DCD pin is valid (active low);<br>0: DCD pin is invalid (high level).<br>Note: Only UART0 supports.      | X              |
| 6   | RB_MSR_RI      | RO     | RI pin status bit:<br>1: RI pin is valid (active low);<br>0: RI pin is invalid (high level).<br>Note: Only UART0 supports.         | X              |
| 5   | RB_MSR_DSR     | RO     | DSR pin status bit:<br>1: DSR pin is valid (active low);<br>0: DSR pin is invalid (high level).<br>Note: Only UART0 supports.      | x              |
| 4   | RB_MSR_CTS     | RO     | CTS pin status bit:<br>1: CTS pin is valid (active low);<br>0: CTS pin is invalid (high level).<br>Note: Only UART0 supports.      | X              |
| 3   | RB_MSR_DCD_CHG | RZ     | DCD pin input status change flag bit:<br>1: Change;<br>0: No change.<br>Note: Only UART0 supports.                                 | 0              |
| 2   | RB_MSR_RI_CHG  | RZ     | <ul><li>RI pin input status change flag bit:</li><li>1: Change;</li><li>0: No change.</li><li>Note: Only UART0 supports.</li></ul> | 0              |
| 1   | RB_MSR_DSR_CHG | RZ     | DSR pin input status change flag bit:<br>1: Change;<br>0: No change.<br>Note: Only UART0 supports.                                 | 0              |
| 0   | RB_MSR_CTS_CHG | RZ     | CTS pin input status change flag bit:<br>1: Change;<br>0: No change.<br>Note: Only UART0 supports.                                 | 0              |

### Receive buffer register (R8\_UARTx\_RBR) (x=0/1/2/3)

| Bit   | Name         | Access | Description                                                                                                                                                                                                         | Reset<br>value |
|-------|--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_UARTx_RBR | RO     | Data receive buffer register.<br>If the DATA_RDY bit of LSR is 1, the<br>received data can be read from this register;<br>If FIFO_EN is 1, the data received from<br>UART shift register RSR will be firstly stored | х              |

|  | in the receiver FIFO, and then read out |  |
|--|-----------------------------------------|--|
|  | through the register                    |  |

#### Transmit hold register (R8\_UARTx\_THR) (x=0/1/2/3)

| Bit   | Name         | Access | Description                                                                                                                                                                                                                                                          | Reset<br>value |
|-------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_UARTx_THR | WO     | Transmit hold register.<br>Transmitter FIFO is included, used to write<br>the data to be transmitted. If FIFO_EN is 1,<br>the written data will be firstly stored in the<br>transmitter FIFO, and then output one by one<br>through the transmit shift register TSR. | х              |

### Receiver FIFO count register (R8\_UARTx\_RFC) (x=0/1/2/3)

| Bit   | Name         | Access | Description                                                      | Reset<br>value |
|-------|--------------|--------|------------------------------------------------------------------|----------------|
| [7:0] | R8_UARTx_RFC | RO     | Data count in the current receiver FIFO. The maximum value is 8. | Х              |

### Transmitter FIFO count register (R8\_UARTx\_TFC) (x=0/1/2/3)

| Bit   | Name         | Access | Description                                                            | Reset<br>value |
|-------|--------------|--------|------------------------------------------------------------------------|----------------|
| [7:0] | R8_UARTx_TFC | RO     | Data count in the current transmitter FIFO.<br>The maximum value is 8. | х              |

### Baud rate divisor latch (R16\_UARTx\_DL) (x=0/1/2/3)

| Bit    | Name         | Access | Description                                                                                                                                                                                                                                                                                                                                | Reset<br>value |
|--------|--------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | R16_UARTx_DL | RW     | <ul> <li>16-bit divisor, used to calculate the baud rate.</li> <li>Formula: Divisor = the internal reference clock of UART / 16 / the required communication baud rate.</li> <li>For example: If the internal reference clock of UART is 1.8432MHz and the required baud rate is 9600bps, then the divisor =1843200/16/9600=12.</li> </ul> | Х              |

### Pre-frequency division divisor register (R8\_UARTx\_DIV) (x=0/1/2/3)

| Bit   | Name         | Access | Description                                                                                                                                                                                                                                                                                                                      | Reset<br>value |
|-------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_UARTx_DIV | RW     | Used to calculate the internal reference clock<br>of UART, the lower 7 bits are valid<br>Formula: Divisor = Fsys*2 / internal<br>reference clock of UART, with a maximum<br>value of 127.<br>Example: If the system main clock is 96MHz<br>and the divisor is 104, then the internal<br>reference clock of UART is 1.846MHz, and | х              |

| - |  |                                            |  |
|---|--|--------------------------------------------|--|
|   |  | the difference between it and the commonly |  |
|   |  | used reference clock 1.8432 is 0.16%       |  |

Slave address register (R8 UART0 ADR) Only used by UART0

| Bit   | Name         | Access | Description                                                     | Reset<br>value |
|-------|--------------|--------|-----------------------------------------------------------------|----------------|
| [7:0] | R8_UART0_ADR | RW     | UART0 slave address:<br>FFh: Not used;<br>Other: Slave address. | 8hFF           |

R8\_UART0\_ADR presets the address of this computer as a slave, which is used to automatically compare the received addresses during multi-device communication, and generate an interrupt when the address matches or when the broadcast address 0FFH is received. Meanwhile, it is allowed to receive subsequent data packets. It is not allowed to receive any data before the address does not match. After sending data or rewriting to the R8\_UART0\_ADR register, stop receiving any data, until the address is matched again next time or the broadcast address is received.

When R8\_UART0\_ADR is 0FFH or RB\_LCR\_PAR\_EN=0, the automatic comparison function of bus address is disabled.

When R8\_UART0\_ADR is not 0FFH and RB\_LCR\_PAR\_EN=1, the automatic comparison function of bus address is enabled, and the following parameters should be configured: RB\_LCR\_WORD\_SZ is 11b to select 8 data bits. For the case when the address byte is MARK (that is, the bit 9 of data byte is 0), RB\_LCR\_PAR\_MOD should be set to 10b; for the case when the address byte is SPACE (that is, the bit 9 of data byte is 1), RB\_LCR\_PAR\_MOD should be set to 11b.

### 7.3 UART Application

The UART0/1/2/3 output pins of CH567 chip are all at 3.3V LVCMOS level. The pins in asynchronous serial port mode include: data transmission pins (supported by UART0/1/2/3) and MODEM contact signal pins (only supported by UART0). Data transmission pins include: TXD pin and RXD pin, both of which are at high level by default. MODEM contact signal pins include: CTS pin, DSR pin, RI pin, DCD pin, DTR pin, RTS pin, all of which are at high level by default. All these MODEM communication signals can be used as general-purpose IO pins, controlled by the application program and their purposes can be defined.

4 sets of UARTs each has built-in independent receive/transmit buffer and 8-byte FIFO, they support simplex, half-duplex or full duplex asynchronous serial communication. Serial data includes 1 low-level start bit, 5/6/7/8 data bits, 0 or 1 additional check bit or flag bit, 1 or 2 high-level stop bits, and supports odd/even/mark/blank check. Common communication baud rates are supported: 1200, 2400, 4800, 9600, 19.2K, 38.4K, 57.6K, 115.2K, 230.4K, 460.8K, 921.6K, 1.8432M, 2.7648M, 7.8125M, etc. The baud rate error of UART transmit signal is less than 0.2%, and the allowable baud rate error of UART receive signal is not greater than 2%.

#### 7.3.1 Baud Rate Calculation

1) Calculate the reference clock, set the R8\_UART0\_DIV register, with the maximum value of 127;

2) Calculate the baud rate and set R16 UART0 DL register;

formula: Baud rate =Fsys \* 2 / R8\_UART0\_DIV / 16 / R16\_UART0\_DL.

#### 7.3.2 UART Transmission

"THR register empty" interrupt sent by UART (the low 4 bits of IIR register are 02H) refers to transmitter FIFO empty. The interrupt is cleared when the IIR is read, or the interrupt may be cleared when the next data is written to THR. If only one byte is written to THR, it will soon generate a request of "transmit hold register (THR) empty interrupt" as the byte is quickly transferred to the transmit shift register

(TSR) to start transmitting. At this point, the next data ready to be transmitted can be written. After all data in TSR is removed, UART transmission is completed and RB\_LSR\_TX\_ALL\_EMP bit of LSR changes to 1 and becomes valid.

In interrupt trigger mode, when UART transmit hold register THR empty interrupt is received, if FIFO is enabled, up to 8 bytes can be written to THR and FIFO at a time and will be transmitted automatically by the controller in sequence. If FIFO is disabled, only one byte can be written at a time. If no data needs to be transmitted, simply exit (the interrupts have been automatically cleared when IIR is read earlier).

In the query mode, it can judge whether the transmitter FIFO is empty according to RB\_LSR\_TX\_FIFO\_EMP bit of LSR. If this bit is 1, data can be written to THR and FIFO. If FIFO is enabled, up to 8 bytes can be written at a time.

#### 7.3.3 UART Reception

UART receive data available interrupt (the low 4 bits of IIR are 04H) means that the number of existing data bytes in the receiver FIFO has reached or exceeded the FIFO trigger points set and selected by RB\_FCR\_FIFO\_TRIG of FCR register. The interrupt is cleared when the data is read from RBR to cause the number of bytes in the FIFO below the FIFO trigger point.

UART receive data timeout interrupt (the low 4 bits of IIR are 0CH) means that there is at least one byte of data in the receiver FIFO, and it has waited for the time equivalent to the time for receiving 4 data when UART receives data last time and the MCU takes the data last time. The interrupt is cleared when a new data is received again, or the interrupt can also be cleared when the MCU reads RBR once. When receiver FIFO is empty, RB\_LSR\_DATA\_RDY bit of LSR is 0. When there is data in receiver FIFO, RB LSR DATA RDY bit is 1 and valid.

In the interrupt trigger mode, R8\_UARTx\_RFC register can be read to query the remaining data count in the current FIFO after receiving UART receive data timeout interrupt, read all data directly, or continuously query the RB\_LSR\_DATA\_RDY bit of LSR. If this bit is valid, read the data until this bit becomes invalid. After receiving UART receive data available interrupt, you can read the number of bytes set by RB\_FCR\_FIFO\_TRIG of FCR from RBR, and then directly read the data for the number of bytes, or you can read all the data in the current FIFO according to the RB\_LSR\_DATA\_RDY bit and the R8\_UARTx\_RFC register.

In query mode, the MCU can judge whether the receiver FIFO is empty according to the RB\_LSR\_DATA\_RDY bit of LSR, or read the R8\_UARTx\_RFC register to get the data count in the current FIFO and get all the data received by UART.

#### 7.3.4 Hardware Flow Control

Hardware flow control includes automatic CTS (RB\_MCR\_AU\_FLOW\_EN of MCR is 1) and automatic RTS (RB\_MCR\_AU\_FLOW\_EN and RB\_MCR\_RTS of MCR are 1).

If automatic CTS is enabled, CTS pin must be valid before UART transmits data. UART transmitter detects CTS pin before transmitting the next data. When CTS pin state is valid, the transmitter transmits the next data. In order to ensure that transmitter stops sending the later data, CTS pin must be invalidated before the middle time of the last stop bit currently transmitted. The automatic CTS function reduces the interrupt applied to MCU system. When hardware flow control is enabled, a change of CTS pin level does not trigger a MODEM interrupt as the controller automatically controls the transmitter based on CTS pin status. If automatic RTS is enabled, RTS pin output will be valid only when there is enough space in FIFO to receive data, and RTS pin output is invalid when the receiver FIFO is full. RTS pin output will be valid if all the data in the receiver FIFO is taken or cleared. When the trigger point for the receiver FIFO is reached (the number of existing bytes in the receiver FIFO is not less than the number of bytes set by RB\_FCR\_FIFO\_TRIG of FCR), RTS pin output is invalid, and the transmitter of the other side is allowed to send another data after RTS pin is invalid. Once the data in the receiver FIFO is emptied, RTS pin will be automatically re-enabled, so that the transmitter of the other side restores transmitting. If both automatic CTS and automatic RTS are enabled (both RB\_MCR\_AU\_FLOW\_EN and RB\_MCR\_RTS of MCR register are 1), one side will not

transmit data unless there is enough space in the receiver FIFO of the other side when RTS pin of one side is connected to CTS pin of the other side. Therefore, the hardware flow control can avoid FIFO overflow and timeout errors during UART reception.

# **Chapter 8 General purpose Timer (TMRx)**

# 8.1 Introduction to TMRx

CH567 chip is equipped with 3 26-bit timers, TMR0, TMR1 and TMR2, and the longest timing interval is 2^26 clock cycles. All timers support capture, PWM and interrupt functions. In addition, TMR1 and TMR2 support DMA functions.

Features:

(1). 3 26-bit timers, and the longest timing interval of each timer is 2^26 clock cycles;

(2). Each timer supports PWM function;

(3). Each timer supports capture function;

(4). Timer interrupt is supported by each timer, and among them, TMR1 and TMR2 support DMA and interrupt;

(5). The capture function can be set to level change capture function and high or low level hold time capture function;

(6). PWM function supports dynamically adjust PWM duty cycle settings;

# **8.2 Register Description**

TMR0 related register physical start address: 0x0040 2000 TMR1 related register physical start address: 0x0040 2400 TMR2 related register physical start address: 0x0040 2800

| Name               | Offset address | Description                        | Reset value  |
|--------------------|----------------|------------------------------------|--------------|
| R8_TMR0_CTRL_MOD   | 0x00           | Mode setting register              | 8h02         |
| R8_TMR0_INTER_EN   | 0x02           | Interrupt enable register          | 8h00         |
| R8_TMR0_INT_FLAG   | 0x06           | Interrupt flag register            | 8h00         |
| R8_TMR0_FIFO_COUNT | 0x07           | FIFO count register                | 8h00         |
| R32_TMR0_COUNT     | 0x08           | Current count value register       | 32h0000 0000 |
| R32_TMR0_CNT_END   | 0x0C           | Final count value setting register | 32h0000 0000 |
| R32_TMR0_FIFO      | 0x10           | FIFO register                      | 32h0000 0000 |

Table 8-1 List of TMR0 Related Registers

Table 8-2 List of TMR1 Related Registers

| Name               | Offset address | Description                   | Reset value  |
|--------------------|----------------|-------------------------------|--------------|
| R8_TMR1_CTRL_MOD   | 0x00           | Mode setting register         | 8h02         |
| R8_TMR1_CTRL_DMA   | 0x01           | DMA control register          | 8h00         |
| R8_TMR1_INTER_EN   | 0x02           | Interrupt enable register     | 8h00         |
| R8_TMR1_INT_FLAG   | 0x06           | Interrupt flag register       | 8h00         |
| R8_TMR1_FIFO_COUNT | 0x07           | FIFO count register           | 8h00         |
| R32_TMR1_COUNT     | 0x08           | Current count value register  | 32h0000 0000 |
| R32_TMR1_CNT_END   | 0x0C           | Final count value register    | 32h0000 0000 |
| R32_TMR1_FIFO      | 0x10           | FIFO register                 | 32h0000 0000 |
| R16_TMR1_DMA_NOW   | 0x14           | Current address of DMA buffer | 16h0000      |
| R16_TMR1_DMA_BEG   | 0x18           | Start address of DMA buffer   | 16h0000      |
| R16_TMR1_DMA_END   | 0x1C           | End address of DMA buffer     | 16h0000      |

Table 8-3 List of TMR2 Related Registers

| Name               | Offset address | Description                   | Reset value  |
|--------------------|----------------|-------------------------------|--------------|
| R8_TMR2_CTRL_MOD   | 0x00           | Mode setting register         | 8h02         |
| R8_TMR2_CTRL_DMA   | 0x01           | DMA control register          | 8h00         |
| R8_TMR2_INTER_EN   | 0x02           | Interrupt enable register     | 8h00         |
| R8_TMR2_INT_FLAG   | 0x06           | Interrupt flag register       | 8h00         |
| R8_TMR2_FIFO_COUNT | 0x07           | FIFO countregister            | 8h00         |
| R32_TMR2_COUNT     | 0x08           | Current count value register  | 32h0000 0000 |
| R32_TMR2_CNT_END   | 0x0C           | Final count value register    | 32h0000 0000 |
| R32_TMR2_FIFO      | 0x10           | FIFO register                 | 32h0000 0000 |
| R16_TMR2_DMA_NOW   | 0x14           | Current address of DMA buffer | 16h0000      |
| R16_TMR2_DMA_BEG   | 0x18           | Start address of DMA buffer   | 16h0000      |
| R16_TMR2_DMA_END   | 0x1C           | End address of DMA buffer     | 16h0000      |

Mode setting register (R8\_TMRx\_CTRL\_MOD) (x=0/1/2)

| Bit   | Name              | Access | Description                                                                                                                                                                                                                     | Reset<br>value |
|-------|-------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:6] | RB_TMR_CAP_EDGE   | RW     | In capture mode, edge trigger mode setting<br>domain:<br>00: Disable trigger;<br>01: Capture the time between any edge<br>changes;<br>10: Capture the time between falling edges;<br>11: Capture the time between rising edges; | 0              |
| [7:6] | RB_TMR_PWM_REPEAT | RW     | <ul><li>PWM repeat mode setting domain:</li><li>00: Repeat for 1 time;</li><li>01: Repeat for 4 times;</li><li>10: Repeat for 8 times;</li><li>11: Repeat for 16 times.</li></ul>                                               | 0              |
| 5     | Reserved          | RO     | Reserved.                                                                                                                                                                                                                       | 0              |
| 4     | RB_TMR_CAP_COUNT  | RW     | Auxiliaryselection;whenRB_TMR_MODE_IN=1, set:1: Count;0: Capture.                                                                                                                                                               | 0              |
| 4     | RB_TMR_OUT_POLAR  | RW     | In PWM mode, output polarity setting bit:<br>1: Default high level, active low;<br>0: Default low level, active high;                                                                                                           | 0              |
| 3     | RB_TMR_OUT_EN     | RW     | Timer output enable bit<br>1: Timer output is enabled;<br>0: Timer output is disabled.                                                                                                                                          | 0              |
| 2     | RB_TMR_COUNT_EN   | RW     | Timer module enable bit:<br>1: Enable;<br>0: Disable.                                                                                                                                                                           | 0              |
| 1     | RB_TMR_ALL_CLEAR  | RW     | <ul><li>FIFO and Count register clear bit of counter:</li><li>1: Force to clear;</li><li>0: No action.</li></ul>                                                                                                                | 1              |
| 0     | RB_TMR_MODE_IN    | RW     | Timer mode setting bit:<br>1: Capture/count mode<br>0: Timing mode/PWM mode                                                                                                                                                     | 0              |

| Bit   | Name               | Access | Description                                                                                                                                                                                                                                                                                      | Reset<br>value |
|-------|--------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:5] | Reserved           | RO     | Reserved.                                                                                                                                                                                                                                                                                        | Х              |
| 4     | RB_TMR_IE_FIFO_OV  | RW     | <ul><li>FIFO overflow interrupt enable bit:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>                                                                                                                                             | 0              |
| 3     | RB_TMR_IE_DMA_END  | RW     | <ul><li>DMA end interrupt enable bit, not supported by TMR0:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>                                                                                                                            | 0              |
| 2     | RB_TMR_IE_FIFO_HF  | RW     | <ul> <li>FIFO half use interrupt enable bit:</li> <li>1: Enable the corresponding interrupt;</li> <li>0: Disable the corresponding interrupt.</li> <li>(capture fifo &gt;=4 or PWM fifo &lt;=3)</li> </ul>                                                                                       | 0              |
| 1     | RB_TMR_IE_DATA_ACT | RW     | In capture mode, level change interrupt<br>enable bit:<br>1: Enable the corresponding interrupt;<br>0: Disable the corresponding interrupt.<br>In PWM mode, PWM completion interrupt<br>enable bit:<br>1: Enable the corresponding interrupt;<br>0: Disable the corresponding interrupt.         | 0              |
| 0     | RB_TMR_IE_CYC_END  | RW     | In capture mode, capture timeout interrupt<br>enable bit:<br>1: Enable the corresponding interrupt;<br>0: Disable the corresponding interrupt.<br>In PWM mode, PWM clock cycle end<br>interrupt enable bit:<br>1: Enable the corresponding interrupt;<br>0: Disable the corresponding interrupt. | 0              |

Interrupt enable register (R8\_TMRx\_INTER\_EN) (x=0/1/2)

### Interrupt flag register (R8\_TMRx\_INT\_FLAG) (x=0/1/2)

| Bit   | Name               | Access | Description                                                                                                                                                                         | Reset<br>value |
|-------|--------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:5] | Reserved           | RO     | Reserved.                                                                                                                                                                           | Х              |
| 4     | RB_TMR_IF_FIFO_OV  | RW1    | FIFO overflow flag bit:<br>1: Overflowed;<br>0: No overflow.                                                                                                                        | 0              |
| 3     | RB_TMR_IF_DMA_END  | RW1    | DMA completion flag bit, not supported by<br>TMR0:<br>1: Completed;<br>0: Not completed.                                                                                            | 0              |
| 2     | RB_TMR_IF_FIFO_HF  | RW1    | <ul> <li>FIFO half count flag bit:</li> <li>1: FIFO has been half counted;</li> <li>0: FIFO has not been half counted.</li> <li>(capture fifo &gt;=4 or PWM fifo &lt;=3)</li> </ul> | 0              |
| 1     | RB_TMR_IF_DATA_ACT | RW1    | In the capture mode, capture level change                                                                                                                                           | 0              |

|   |                   |     | <ul> <li>flag bit:</li> <li>1: Capture the level change;</li> <li>0: No level change is captured.</li> <li>In PWM mode, PWM trigger flag bit:</li> <li>1: Triggered (PWM count reaches the specified value);</li> </ul>                      |   |
|---|-------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 0 | RB_TMR_IF_CYC_END | RW1 | 0: Not triggered.<br>In capture mode, timeout flag bit:<br>1: Timeout;<br>0: Not timeout.<br>In PWM mode, PWM cycle end flag bit:<br>1: End;<br>0: Not end.<br>Timing mode:<br>1: Timing cycle ends;<br>0: Not end.<br>Cleared by writing 1. | 0 |

### FIFO count register (R8\_TMRx\_FIFO\_COUNT) (x=0/1/2)

| Bit   | Name               | Access | Description                                               | Reset<br>value |
|-------|--------------------|--------|-----------------------------------------------------------|----------------|
| [7:0] | R8_TMRx_FIFO_COUNT | RO     | Data byte count in the FIFO, with the maximum value of 8. | х              |

### Current count value register (R32\_TMRx\_COUNT) (x=0/1/2)

| Bit    | Name           | Access | Description                     | Reset<br>value |
|--------|----------------|--------|---------------------------------|----------------|
| [31:0] | R32_TMRx_COUNT | RO     | Current count value of counter. | Х              |

### Final count value setting register (R32\_TMRx\_CNT\_END) (x=0/1/2)

| Bit    | Name             | Access | Description                                                                                                                                                                                                                                                                                                                                       | Reset<br>value |
|--------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:0] | R32_TMRx_CNT_END | RW     | In timer mode, number of timing clocks;<br>In PWM mode, the total number of clocks in<br>PWM cycle;<br>In the capture mode, the number of captured<br>timeout clock cycles;<br>The maximum value is 67108864.<br>Note: R32_TMRx_COUNT counts from 0,<br>so the maximum value is<br>R32_TMRx_CNT_END minus 1.<br>Only the lower 26 bits are valid. | х              |

### FIFO register (R32\_TMRx\_FIFO) (x=0/1/2)

| Bit    | Name          | Access    | Description                                           | Reset<br>value |
|--------|---------------|-----------|-------------------------------------------------------|----------------|
| [31:0] | R32_TMRx_FIFO | RO/<br>WO | FIFO data register, only the lower 26 bits are valid. | х              |

| Bit   | Name                                                                                                                 | Access | Description                                                                                                                                                                                                                                                                                                                                         | Reset<br>value |
|-------|----------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:3] | Reserved                                                                                                             | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                           | Х              |
| 2     | RB_TMR_DMA_LOOP                                                                                                      | RW     | <ul> <li>DMA address loop function enable bit, not supported by TMR0:</li> <li>1: Enable DMA address loop function;</li> <li>0: Disable DMA address loop function.</li> <li>If the DMA address loop mode function is enabled, when the DMA address is added to the set end address, it will automatically loop to the start address set.</li> </ul> | 0              |
| 1     | Reserved                                                                                                             | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                           | 0              |
| 0     | RB_TMR_DMA_ENABLE     RW     DMA function enable bit, not supported by<br>TMR0:<br>1: Enable DMA;<br>0: Disable DMA. |        | 0                                                                                                                                                                                                                                                                                                                                                   |                |

#### DMA current buffer address (R16\_TMRx\_DMA\_NOW) (x=1/2)

| Bit    | Name             | Access | Description                                                                                                                                                          | Reset<br>value |
|--------|------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | R16_TMRx_DMA_NOW | RW     | Current address of DMA data buffer.<br>It can be used to calculate the number of<br>conversions, and the calculation method is:<br>COUNT=(TMR_DMA_NOW-TMR_DMA_BEG)/4 | xxxx           |

#### DMA start buffer address (R16\_TMRx\_DMA\_BEG) (x=1/2)

| Bit    | Name Acces       |    | Description                                                                                                                                                                                          | Reset<br>value |
|--------|------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | R16_TMRx_DMA_BEG | RW | For the start address of DMA data buffer, 4<br>bytes must be aligned for the address.<br>That is, in PWM data transmission or capture<br>mode, the data captured starts from this buffer<br>address. | xxxx           |

#### DMA end buffer address (R16\_TMRx\_DMA\_END) (x=1/2)

| Bit    | Name Access      |    | Description                                                                                                                                                                     | Reset<br>value |
|--------|------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | R16_TMRx_DMA_END | RW | End address of DMA data buffer, 4 bytes must be<br>aligned for the address.<br>That is, in PWM data transmit or capture mode,<br>the data captured ends in this buffer address. | xxxx           |

# 8.3 TMRx Function

### **8.3.1 Timing and Counting Function**

There are 3 timers in CH567, each of which supports a maximum timing interval of 2^26 clock cycles.

If the system clock cycle is 96M, the longest time interval is:  $10.4ns^2^2 \approx 0.7s$ . If the system clock is lower than 96M, the time interval is longer.

3 timers have an independent interrupt.

The register with timing function is initialized as follows:

(1). Set register R32\_TMRx\_CNT\_END to the time value that is needed for timing;

The specific calculation method is: Time = Fsys \* R32\_TMRx\_CNT\_END

(2). Set the RB\_TMR\_MODE\_IN bit of register R8\_TMRx\_CTRL\_MOD to 0, and RB\_TMR\_ALL\_CLEAR to 0;

(3). Set the RB\_TMR\_COUNT\_EN bit of register R8\_TMRx\_CTRL\_MOD to 1, to start the timer function;

(4). At the end of timing interval, set the RB\_TMR\_IF\_CYC\_END bit of register R8\_TMRx\_INT\_FLAG to 1, and cleared by writing 1.

#### **8.3.2 PWM Function**

3 timers of CH567 chip all have PWM function. The default output polarity of PWM can be set to high level or low level. The number of repeat times can be selected as 1, 4, 8 or 16. This repeat function can be combined with DMA to imitate the effect of DAC. The shortest time cycle for PWM output is 1 system clock cycle, and the duty cycle of PWM can be dynamically modified to imitate special waveforms, such as quasi-sine-wave.

PWM function operation:

It is needed to set the register (R32\_TMRx\_FIFO) and register (R32\_TMRx\_CNT\_END) when PWM outputs, R32\_TMRx\_FIFO is the data register, R32\_TMRx\_CNT\_END is the PWM total cycle register.

PWM operation steps are as follows:

(1). Set the PWM total cycle register R32\_TMRx\_CNT\_END, the minimum value is 1, the value of this register must be greater than or equal to the value of R32\_TMRx\_FIFO register;

(2). Set the data register R32\_TMRx\_FIFO, the minimum value is 0, with the corresponding duty cycle of 0%, the maximum value is the same as that of R32\_TMR\_CNT\_END, with the corresponding duty cycle of 100%, the calculation of duty cycle: R32\_TMRx\_FIFO/R32\_TMRx\_CNT\_END. TMR1 and TMR2 support continuous dynamic data (DMA), which can imitate special waveforms;

(3). Clear the RB\_TMR\_MODE\_IN bit of the mode setting register (R8\_TMRx\_CTRL\_MOD) to 0 to enable PWM mode. At the same time, set the RB\_TMR\_ALL\_CLEAR bit to 1 and then clear it to forcefully clear the FIFO and COUNT. Set the RB\_TMR\_OUT\_POLAR bit to select the output polarity. If it is needed to set the number of repeat times, set the RB\_TMR\_PWM\_REPEAT domain as needed.

(4). Set the RB\_TMR\_COUNT\_EN and RB\_TMR\_OUT\_EN bits of the mode setting register (R8\_TMRx\_CTRL\_MOD) to 1 to enable the PWM function;

(5). Set the I/O pin corresponding to PWM as output;

(6). If it is needed to enable interrupts, set the corresponding interrupt enable register bit;

(7). After the PWM is completed, if the interrupt is turned on, the corresponding timer interrupt will be generated. At the same time, read the R8\_TMRx\_INT\_FLAG register to know whether the PWM is completed and whether an error occurred during the PWM process;

For example: Set the RB TMR OUT POLAR bit to 0, R32 TMRx FIFO to 6,

R32\_TMRx\_CNT\_END to 18, the basic timing diagram of generating PWM is as follows, and its duty cycle is:

PWM duty cycle = R32\_TMRx\_FIFO/R32\_TMRx\_CNT\_END = 1/3





If RB\_TMR\_PWM\_REPEAT domain is set to 00, it means that the above process is repeated once, 01 means that the above process is repeated for 4 times, 10 means that the above process is repeated for 8 times, and 11 means that the above process is repeated for 16 times. After repeating, take the next data in FIFO and then continue.

#### 8.3.3 Capture Function

3 timers of CH567 chip all have capture function, among which the capture functions of TMR1 and TMR2 support DMA data storage. Three capture modes can be selected: start triggering at any edge and end at any edge, start triggering at rising edge and end at rising edge, and start triggering at falling edge and end at falling edge. The following is the description of capture trigger mode:

| Capture Mode Selection Bit<br>(RB_TMR_CATCH_EDGE) | Trigger Mode                    | Graphical representation |
|---------------------------------------------------|---------------------------------|--------------------------|
| 00                                                | Disable capture                 | None                     |
| 01                                                | Edge trigger                    |                          |
| 10                                                | Falling edge to<br>falling edge |                          |
| 11                                                | Rising edge to rising<br>edge   |                          |

| Table 8-4 Description of Capture Trigger Mode | Table 8-4 Descr | ription of Cap | ture Trigger Mode |
|-----------------------------------------------|-----------------|----------------|-------------------|
|-----------------------------------------------|-----------------|----------------|-------------------|

There are two trigger states in edge trigger mode, which can capture high level width or low level width. When the highest bit (bit 25) of the valid data in data register (R32\_TMRx\_FIFO) is 1, it indicates that high level is captured. Otherwise, low level is captured. If the bit25 of multiple sets of data is 1 (or 0), the width of the high (or low) level exceeds the timeout value, and multiple sets need to be accumulated.

In the trigger modes from falling edge to falling edge or from rising edge to rising edge, an input change cycle can be captured. When the highest bit (bit 25) of the valid data in data register (R32\_TMRx\_FIFO) is 0, one cycle is normally sampled. When it is 1, the input change period exceeds the timeout value R32\_TMRx\_CNT\_END, and the latter set of data needs to be added and accumulated as a



single input change cycle.

The specific description is shown in the figure below:

Figure 8-2 Taking System Clock Cycle as Capture Cycle

As shown in the figure above, sample once in each clock cycle,

When RB\_TMR\_CATCH\_EDGE = 2b01, it is set as edge-triggered sampling, and the sampled time widths are 3Tsys, 3Tsys, 10Tsys;

When RB\_TMR\_CATCH\_EDGE = 2b10, it is set as the sampling from falling edge to falling edge, and the sampled time width is 13Tsys;

When RB\_TMR\_CATCH\_EDGE = 2b11, it is set as the sampling from rising edge to rising edge, and the sampled time width is 6Tsys.

Operation steps for capture mode:

(1). Set the register R32\_TMRx\_CNT\_END to set the capture timeout time. The default maximum timeout time is 2^26 clock cycles. It is recommended to set a reasonable timeout to avoid no input change for a long time and avoid no time data. If no level change is detected within the maximum timeout time, set bit 25 of R32\_TMRx\_FIFO register to 1;

(2). Set the direction of the I/O pin corresponding to capture as input;

(3). Set the RB\_TMR\_MODE\_IN bit of mode setting register (R8\_TMRx\_CTRL\_MOD) to 1 and set RB\_TMR\_CAP\_COUNT bit to 0, and clear the RB\_TMR\_ALL\_CLEAR bit to clear FIFO and COUNT. At the same time, set the RB\_TMR\_CAP\_EDGE control bit to select the capture mode;

(4). If interrupt needs to be enabled, set the corresponding bit of interrupt register R8\_TMRx\_INTER\_EN to 1, to enable the corresponding interrupt;

(5). To save the captured data by DMA method (only supported by TMR1 and TMR2), you need to set RB\_TMR\_DMA\_ENABLE bit of R8\_TMRx\_CTRL\_DMA register to 1, to enable the DMA function, and set the register R16\_TMRx\_DMA\_BEG to the first address of the buffer for storing the captured data, and set the register R16\_TMRx\_DMA\_ENDMA END as the end address of the buffer for storing captured data;

(6). Set the RB\_TMR\_COUNT\_EN bit of register R8\_TMRx\_CTRL\_MOD to 1, to enable timer module and start the capture function;

(7). After the capture is completed, the register R8\_TMRx\_INT\_FLAG will generate the corresponding interrupt status. The data captured by default is stored in the register R32\_TMRx\_FIFO. If DMA data transmission is used, the captured data will be automatically stored in the data buffer set by DMA.

# **Chapter 9 PWM**

### 9.1 Introduction to PWM Controller

CH567 is provided with 4 channels of PWM output, the duty cycle is adjustable, and the PWM cycle is fixed and 2 modes are available, and the operation is simple.

The extended PWM pin output is identified as PWM3/ PWM4/ PWM5/ PWM6, among which PWM5 and PWM6 support remap to PWM5\_ and PWM6\_ pins.

# 9.2 Register Description

PWM0/1/2/3 related register physical base address: 0x0040 5000

| - | Table 9 | -1 | List of P | WM0/1/2/3 | Related | Re | egisters |
|---|---------|----|-----------|-----------|---------|----|----------|
|   | 0.00    |    |           |           | ъ       |    |          |

| Name Offset address  |      | Description                           | <b>Reset value</b> |
|----------------------|------|---------------------------------------|--------------------|
| R8_PWM_CTRL_MOD      | 0x00 | PWM mode control register             | 8h00               |
| R8_PWM_CTRL_CFG 0x01 |      | PWM configuration control register    | 8h00               |
| R8_PWM_CLOCK_DIV     | 0x02 | PWM clock frequency division register | 8h00               |
| R32_PWM_DATA         | 0x08 | PWM0/1/2/3 data hold register         | 32h                |

#### PWM mode control register (R8\_PWM\_CTRL\_MOD)

| Bit | Name           | Access | Description                        | Reset<br>value |
|-----|----------------|--------|------------------------------------|----------------|
|     |                |        | PWM3 output polarity control bit:  |                |
| 7   | RB_PWM3_POLAR  | RW     | 1: Default high level, active low; | 0              |
|     |                |        | 0: Default low level, active high; |                |
|     |                |        | PWM2 output polarity control bit:  |                |
| 6   | RB_PWM2_POLAR  | RW     | 1: Default high level, active low; | 0              |
|     |                |        | 0: Default low level, active high; |                |
|     |                |        | PWM1 output polarity control bit:  |                |
| 5   | RB_PWM1_POLAR  | RW     | 1: Default high level, active low; | 0              |
|     |                |        | 0: Default low level, active high; |                |
|     |                |        | PWM0 output polarity control bit:  |                |
| 4   | RB_PWM0_POLAR  | RW     | 1: Default high level, active low; | 0              |
|     |                |        | 0: Default low level, active high; |                |
|     |                |        | PWM3 output enable bit:            |                |
| 3   | RB_PWM3_OUT_EN | RW     | 1: Enable;                         | 0              |
|     |                |        | 0: Disable.                        |                |
|     |                |        | PWM2 output enable bit:            |                |
| 2   | RB_PWM2_OUT_EN | RW     | 1: Enable;                         | 0              |
|     |                |        | 0: Disable.                        |                |
|     |                |        | PWM1 output enable bit:            |                |
| 1   | RB_PWM1_OUT_EN | RW     | 1: Enable;                         | 0              |
|     |                |        | 0: Disable.                        |                |
|     |                |        | PWM0 output enable bit:            |                |
| 0   | RB_PWM0_OUT_EN | RW     | 1: Enable;                         | 0              |
|     |                |        | 0: Disable.                        |                |

#### PWM configuration control register (R8 PWM CTRL CFG)

| Bit   | Name             | Access | Description          | Reset<br>value |
|-------|------------------|--------|----------------------|----------------|
| [7:1] | Reserved         | RW     | Reserved.            | 0              |
|       |                  |        | PWM cycle selection: |                |
| 0     | RB_PWM_CYCLE_SEL | RW     | 1: 255 clock cycles; | 0              |
|       |                  |        | 0: 256 clock cycles. |                |

#### PWM clock divider register (R8\_PWM\_CLOCK\_DIV)

| Bit   | Name             | Access | Description                                                                                  | Reset<br>value |
|-------|------------------|--------|----------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_PWM_CLOCK_DIV | RW     | PWM reference clock frequency division factor.<br>Calculation:<br>CLK=Fsys/R8_PWM_CLOCK_DIV. | 0              |

PWM0/1/2/3 data hold register (R32 PWM DATA)

| Bit     | Name         | Access | Description              | Reset<br>value |
|---------|--------------|--------|--------------------------|----------------|
| [31:24] | R8_PWM3_DATA | RW     | PWM3 data hold register. | XX             |
| [23:16] | R8_PWM2_DATA | RW     | PWM2 data hold register. | XX             |
| [15:8]  | R8_PWM1_DATA | RW     | PWM1 data hold register. | XX             |
| [7:0]   | R8_PWM0_DATA | RW     | PWM0 data hold register. | XX             |

## 9.3 PWM Configuration

1) Set PWM0-PWM3 pin direction as output; optionally, set the drive capability of corresponding I/O;

2) Set the register R8 PWM CLOCK DIV to calculate the clock reference frequency of PWM;

3) Set the PWM mode control register R8\_PWM\_CTRL\_MOD, configure the output polarity of PWMx, and enable the corresponding PWMx (RB\_PWMx\_OUT\_EN position 1) output;

4) Set the R8\_PWM\_CTRL\_CFG register and R32\_PWM\_DATA register to configure the PWM duty cycle output.

Calculation formula:

PWMx duty cycle = R8\_PWMx\_DATA / (RB\_PWM\_CYCLE\_SEL? 255 : 256)

Note: If the corresponding RB\_PWMx\_OUT\_EN output enable is always on in the R8\_PWM\_CTRL\_MOD register, the PWM waveform will be output continuously until RB\_PWMx\_OUT\_EN is disabled.

# **Chapter 10 LED Screen Controller**

### **10.1 Introduction to LED Controller**

CH567 is equipped with an LED screen control card interface and built-in 4-byte FIFO, which supports DMA and interrupts, saves CPU processing time and supports 1/2/4-channel data line interfaces.

## **10.2 Register Description**

LED related register physical base address: 0x0040 6000

Table 10-1 List of LED Related Registers

| Name             | Offset address | Description                       | Reset value |
|------------------|----------------|-----------------------------------|-------------|
| R8_LED_CTRL_MOD  | 0x00           | LED mode configuration register   | 8h02        |
| R8_LED_CLOCK_DIV | 0x01           | LED serial clock divider register | 8hxx        |
| R8_LED_STATUS    | 0x04           | LED status register               | 8h00        |
| R16_LED_FIFO     | 0x08           | LED FIFO register                 | 16hxxxx     |
| R16_LED_DMA_CNT  | 0x10           | LED DMA remaining count register  | 16hxxxx     |
| R16_LED_DMA_MAIN | 0x14           | LED main buffer DMA address       | 16hxxxx     |
| R16_LED_DMA_AUX  | 0x18           | LED auxiliary buffer DMA address  | 16hxxxx     |

LED mode configuration register (R8\_LED\_CTRL\_MOD)

| Bit   | Name             | Access | Description                                                                                                                                                                                                                                           | Reset<br>value |
|-------|------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:6] | RB_LED_CHAN_MOD  | RW     | LED channel mode setting domain:<br>00: LED0, single channel output;<br>01: LED0/1, dual channel output;<br>10: LED0~3, 4-channel output;<br>11: LED0~3, 4-channel output, among which the<br>data of LED2/3 channels comes from auxiliary<br>buffer. | 0              |
| 5     | RB_LED_IE_FIFO   | RW     | <ul><li>FIFO half count interrupt enable:</li><li>1: FIFO count&lt;=2 interrupt trigger;</li><li>0: Disable the corresponding interrupt.</li></ul>                                                                                                    | 0              |
| 4     | RB_LED_DMA_EN    | RW     | LED DMA function and DMA interrupt enable:<br>1: Enable;<br>0: Disable.                                                                                                                                                                               | 0              |
| 3     | RB_LED_OUT_EN    | RW     | LED signal output:<br>1: Enable;<br>0: Disable.                                                                                                                                                                                                       | 0              |
| 2     | RB_LED_OUT_POLAR | RW     | <ul><li>LED data output polarity control bit:</li><li>1: Flip output, data 0 outputs 1, data 1 outputs 0;</li><li>0: Direct output, data 0 outputs 0, data 1 outputs 1.</li></ul>                                                                     | 0              |
| 1     | RB_LED_ALL_CLEAR | RW     | Clear LED FIFO and counter:<br>1: Force to clear;<br>0: No action.                                                                                                                                                                                    | 1              |
| 0     | RB_LED_BIT_ORDER | RW     | LED serial data bit sequence:                                                                                                                                                                                                                         | 0              |

| г <u> </u> |  |                            |  |
|------------|--|----------------------------|--|
|            |  | 1: High byte is the first; |  |
|            |  | i ingli oʻj to ib tiloti,  |  |
|            |  | 0: Low byte is the first;  |  |
|            |  | o. Low offers the first,   |  |

#### LED serial clock divider register (R8\_LED\_CLOCK\_DIV)

| Bit   | Name             | Access | Description                                                                                       | Reset<br>value |
|-------|------------------|--------|---------------------------------------------------------------------------------------------------|----------------|
| [7:0] | R8_LED_CLOCK_DIV | RW     | LED control output clock frequency division<br>factor.<br>Calculation: CLK=Fsys/R8_LED_CLOCK_DIV. | xx             |

#### LED status register (R8\_LED\_STATUS)

| Bit   | Name               | Access | Description                                   | Reset<br>value |
|-------|--------------------|--------|-----------------------------------------------|----------------|
|       |                    |        | DMA transmission completion flag bit:         |                |
| 7     | DD I ED IE DMA END | RW1    | 1: DMA transmission is completed;             | 0              |
| /     | RB_LED_IF_DMA_END  | KW I   | 0: Not completed.                             | 0              |
|       |                    |        | Cleared by writing 1 or R16_LED_DMA_CNT       |                |
|       |                    |        | FIFO empty status bit:                        |                |
| 6     | RB_LED_FIFO_EMPTY  | RO     | 1: FIFO is empty;                             | 0              |
|       |                    |        | 0: FIFO is not empty.                         |                |
|       |                    |        | FIFO half count interrupt flag bit:           |                |
| 5     | RB LED IF FIFO     | RW1    | 1: FIFO count <= 2;                           | 0              |
| 5     | KD_LED_IF_FIFU     | KW I   | 0: FIFO count $> 2$ .                         | 0              |
|       |                    |        | Cleared by writing 1 or R16_LED_FIFO          |                |
|       |                    |        | Current LED clock signal level status:        |                |
| 4     | RB_LED_CLOCK       | 0      | 1: High level;                                | 0              |
|       |                    |        | 0: Low level.                                 |                |
| 3     | Reserved           | RO     | Reserved.                                     | 0              |
| [2:0] | DD LED FIEO COUNT  | RO     | The byte count in the current FIFO must be an | 0              |
| [2:0] | RB_LED_FIFO_COUNT  | KÜ     | even number.                                  | 0              |

#### LED FIFO register (R16\_LED\_FIFO)

| Bit    | Name         | Access | Description                        | Reset<br>value |
|--------|--------------|--------|------------------------------------|----------------|
| [15:0] | R16_LED_FIFO | WO     | LED data FIFO entry, 16-bit write. | XXXX           |

#### LED DMA remaining count register (R16\_LED\_DMA\_CNT)

| Bit    | Name            | Access | Description                                                                                                                                                                                               | Reset<br>value |
|--------|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | R16_LED_DMA_CNT | RW     | Current DMA remaining word (16-bit) count of LED_DMA_MAIN main buffer area. It will automatically decrease after DMA is started and only the lower 12 bits are valid. Auxiliary buffers are not included. | xxxx           |

#### LED main buffer DMA address (R16\_LED\_DMA\_MAIN)

| BitNameAccessDescriptionReservation |
|-------------------------------------|
|-------------------------------------|

| [15:0] R16_LED_D | MA_MAIN RW | <ul><li>DMA start address/current address of the main</li><li>buffer area, is automatically increased after the</li><li>initial value is preset.</li></ul> | XXXX |
|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------|

LED auxiliary buffer DMA address (R16\_LED\_DMA\_AUX)

| Bit    | Name            | Access | Description                                                                                                                     | Reset<br>value |
|--------|-----------------|--------|---------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | R16_LED_DMA_AUX | RW     | DMA start address/current address of auxiliary<br>buffer area, is automatically increased after the<br>initial value is preset. | xxxx           |

### **10.3 LED Control Application**

1) Set LEDC and the necessary LED0  $\sim$  LED3 pin directions as output, optionally, set the corresponding I/O drive capability;

2) Set R8\_LED\_CLOCK\_DIV to select the LED output clock frequency;

3) Set the DMA start address R16\_LED\_DMA\_MAIN to point to the buffer that is ready to output data, that is, the main buffer;

4) If LED channel mode 3 is selected, the auxiliary DMA start address R16\_LED\_DMA\_AUX must be set to point to the auxiliary buffer;

5) Set the LED control register R8\_LED\_CTRL\_MOD, select the channel mode, output polarity, bit sequence, enable interrupt and DMA functions, etc.;

6) Set the DMA count register R16\_LED\_DMA\_CNT, to start DMA transmission, or transmit data by writing to FIFO;

7) Query or use interrupt processing to interrupt the corresponding status.

### **11.1 Introduction to USB Controller**

CH567 is embedded with two-channel USB2.0 controller and USB-PHY, with dual roles of host controller and USB device controller. When used as a host controller, they can support low-speed, full-speed and high-speed USB devices. When used as a device controller, it can be flexibly set to low-speed, full-speed or high-speed mode, to adapt to various applications.

The features of USB0 and USB1 controllers are as follows:

- 1) Support USB 2.0, USB 1.1 and USB 1.0;
- 2) Support USB Host functions and USB Device functions;
- 3) Host supports high-speed HUB;
- 4) The hardware can be configured as high-speed, full-speed and low-speed device;

5) Both the host and the device support control transmission, batch transmission, interrupt transmission, real-time/synchronous transmission;

- 6) Support directly access the data of each endpoint buffer by DMA;
- 7) Support suspend, remote wake-up and resume functions;

8) Except device endpoint 0, all other endpoints support the data packets up to 512 bytes, and some endpoints support double buffering.

### **11.2 Register Description**

CH567 is integrated with double USB2.0 master-slave controller (built-in PHY), USB0 and USB1, and can be flexibly configured as host function or device function.

The USB0 and USB1 related registers of CH567 are divided into 3 parts, some of which are multiplexed in the host and device modes.

- 1) USB global register;
- 2) USB device controller register;
- 3) USB host controller register.

USB0 related register physical base address: 0x0040 8000 USB1 related register physical base address: 0x0040 9000

#### 11.2.1 Global Register Description

| Name            | Offset address | Description                       | Reset value  |
|-----------------|----------------|-----------------------------------|--------------|
| USBx_CTRL       | 00h            | USB control register              | 8h06         |
| USBx_INT_EN     | 02h            | USB interrupt enable register     | 8h00         |
| USBx_DEV_AD     | 03h            | USB device address register       | 8h00         |
| USBx_FRAME_NO   | 04h            | USB frame number register         | 16h0000      |
| USBx_SUSPEND    | 06h            | USB suspend control register      | 8h00         |
| USBx_SPPED_TYPE | 08h            | USB current speed type register   | 8h00         |
| USBx_MIS_ST     | 09h            | USB miscellaneous status register | 8hxx10_1000b |
| USBx_INT_FG     | 0Ah            | USB interrupt flag register       | 8h00         |
| USBx_INT_ST     | 0Bh            | USB interrupt status register     | 8h00xx_xxxb  |
| USBx_RX_LEN     | 0Ch            | USB receive length register       | 16hxxxx      |

Table 11-1 List of USB Global Registers

### USB control register (USBx\_CTRL) (x=0/1)

| Bit   | Name          | Access | Description                                                                                                                                                                                                                                                                                                                                        | Reset<br>value |
|-------|---------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7     | bUC_HOST_MODE | RW     | USB working mode selection bit:<br>0: Device mode (DEVICE);<br>1: Host mode (HOST).                                                                                                                                                                                                                                                                | 0              |
| [6:5] | UC_SPEED_TYPE | RW     | USB bus signal transmission rate selection bit:<br>00: Full speed;<br>01: High speed;<br>10: Low speed.                                                                                                                                                                                                                                            | 00Ь            |
| 4     | bUC_DEV_PU_EN | RW     | In device mode, USB device enable and internal<br>pull-up resistor control bit:<br>1: Enable USB device transmission and enable<br>internal pull-up resistor;<br>0: Disable.                                                                                                                                                                       | 0              |
| 3     | bUC_INT_BUSY  | RW     | Automatic suspend enable bit before USB transmission completion interrupt flag is not cleared:<br>1: It will automatically suspend before the interrupt flag UIF_TRANSFER is not cleared.<br>It will automatically respond to busy NAK in device mode, and will automatically suspend the subsequent transmission in host mode;<br>0: Not suspend. | 0              |
| 2     | bUC_RESET_SIE | RW     | Software reset control bit of USB protocol<br>processor:<br>1: Forcibly resetting the USB protocol<br>processor (SIE), it needs to be cleared by<br>software;<br>0: Not reset.                                                                                                                                                                     | 1              |
| 1     | bUC_CLR_ALL   | RW     | <ol> <li>1: Empty USB interrupt flag and FIFO, it needs<br/>software to clear;</li> <li>0: Not empty.</li> </ol>                                                                                                                                                                                                                                   | 1              |
| 0     | bUC_DMA_EN    | RW     | <ul> <li>DMA and DMA interrupt control bit of USB:</li> <li>1: enable the DMA function and DMA interrupt;</li> <li>0: Switch off DMA.</li> </ul>                                                                                                                                                                                                   | 0              |

### USB interrupt enable register (USBx\_INT\_EN) (x=0/1)

| Bit | Name         | Access | Description                                                                                                                                                            | Reset<br>value |
|-----|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | bUIE_DEV_SOF | RW     | <ul><li>In USB device mode, receive SOF packet<br/>interrupt:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul> | 0              |
| 6   | bUIE_DEV_NAK | RW     | In USB device mode, receive NAK interrupt:<br>1: Enable the corresponding interrupt;<br>0: Disable the corresponding interrupt.                                        | 0              |
| 5   | Reserved     | RO     | Reserved.                                                                                                                                                              | 0              |

| 4 | bUIE_FIFO_OV  | RW | <ul><li>FIFO overflow interrupt:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>                                                          | 0 |
|---|---------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 3 | bUIE_HST_SOF  | RW | In USB host mode, SOF timing interrupt:<br>1: Enable the corresponding interrupt;<br>0: Disable the corresponding interrupt.                                                                       | 0 |
| 2 | bUIE_SUSPEND  | RW | <ul><li>USB bus suspend or wake-up event interrupt:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>                                       | 0 |
| 1 | bUIE_TRANSFER | RW | <ul><li>USB transfer completion interrupt:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>                                                | 0 |
| 0 | bUIE_DETECT   | RW | <ul><li>In USB host mode, the USB device connection<br/>or disconnection event interrupt:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul> | 0 |
| 0 | bUIE_BUS_RST  | RW | <ul><li>In USB device mode, USB bus reset event<br/>interrupt:</li><li>1: Enable the corresponding interrupt;</li><li>0: Disable the corresponding interrupt.</li></ul>                            | 0 |

#### USB device address register (USBx\_DEV\_AD) (x=0/1)

| Bit   | Name          | Access | Description                                                                                                                              | Reset<br>value |
|-------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7     | Reserved      | RO     | Reserved.                                                                                                                                | 0              |
| [6:0] | MASK_USB_ADDR | RW     | In host mode, it is the address of the USB device being operated or HUB address;<br>In device mode, it is the address of the USB device. | 00h            |

#### USB frame number register (USBx\_FRAME\_NO) (x=0/1)

| Bit    | Name         | Access | Description                                                                                                                                                                                                                                                                                                                    | Reset<br>value |
|--------|--------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | USB_FRAME_NO | RO     | Frame number, it refers to the frame number of<br>the SOF packet to be sent in host mode, and it<br>refers to the frame number of the SOF packet<br>currently received in device mode. Among<br>them, the lower 11 bits are the valid frame<br>number, and the higher 3 bits are the micro<br>frame number of high-speed mode. | 0              |

USBx\_FRAME\_NO is a 16-bit register; among them, the lower 11 bits represent the SOF packet frame number, and the higher 3 bits represents the current micro-frame nomber, which can be used for interrupt, synchronous/real-time transmission when operating high-speed HUB.

USB suspend register (USBx\_SUSPEND) (x=0/1)

| Bit   | Name     | Access | Description | Reset<br>value |
|-------|----------|--------|-------------|----------------|
| [7:2] | Reserved | RO     | Reserved.   | 0              |

| 1 | bUS_RESUME | RW | Remote wake-up control bit:<br>1: Wake up the host remotely;<br>0: No action. | 0 |
|---|------------|----|-------------------------------------------------------------------------------|---|
| 0 | Reserved   | RO | Reserved.                                                                     | 0 |

Note: When remote wake-up is required, pull the bUS\_RESUME bit up and then down.

#### USB speed type register (USBx\_SPEED\_TYPE) (x=0/1)

| Bit   | Name           | Access | Description                                                                                                                                                                                                   | Reset<br>value |
|-------|----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:2] | Reserved       | RO     | Reserved.                                                                                                                                                                                                     | 0              |
| [1:0] | USB_SPEED_TYPE | RO     | In host mode, it refers to the speed type of the<br>currently connected device. In device mode, it<br>refers to the speed type of the current device.<br>00: Full speed;<br>01: High speed;<br>10: Low speed. | 00Ъ            |

Note: Different from UC\_SPEED\_TYPE in USBx\_CTRL register, UC\_SPEED\_TYPE represents the highest speed expected. Assuming that in device mode, set UC\_SPEED\_TYPE to high speed. When the device is connected to a host at full speed, the actual speed type is full speed and it can be known by querying USB\_SPEED\_TYPE register. In host mode, set UC\_SPEED\_TYPE to high speed. When a device at full speed is connected, the actual communication speed is full speed and it can be known by querying the USBx\_SPEED\_TYPE register.

| Bit | Name            | Access | Description                                                                                                                                                                                                                   | Reset<br>value |
|-----|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | bUMS_SOF_PRES   | RO     | <ul> <li>SOF packet indication status bit in USB host mode:</li> <li>1: SOF packet will be sent, and it will be automatically delayed if there are other USB data packets;</li> <li>0: No SOF packet will be sent.</li> </ul> | x              |
| 6   | bUMS_SOF_ACT    | RO     | <ul><li>SOF packet transmission status bit in USB host mode:</li><li>1: SOF packet is being sent out;</li><li>0: The transmission is completed or idle.</li></ul>                                                             | x              |
| 5   | bUMS_SIE_FREE   | RO     | <ul><li>Idle status bit of USB protocol processor:</li><li>1: Idle protocol processor;</li><li>0: Busy, USB transmission is in progress.</li></ul>                                                                            | 1              |
| 4   | bUMS_R_FIFO_RDY | RO     | USB receiver FIFO data ready status bit:<br>1: Receiver FIFO is non-empty;<br>0: Receiver FIFO is empty.                                                                                                                      | 0              |
| 3   | bUMS_BUS_RESET  | RO     | <ul><li>USB bus reset status bit:</li><li>1: The current USB bus is at reset status;</li><li>0: The current USB bus is at non-reset status.</li></ul>                                                                         | 0              |
| 2   | bUMS_SUSPEND    | RO     | <ul><li>USB suspend status bit:</li><li>1: The USB bus is in a suspended state, and there is no USB activity for a period of time;</li><li>0: USB bus is at non-suspended status.</li></ul>                                   | 0              |

USB miscellaneous status register (USBx MIS ST) (x=0/1)

| 1 | bUMS_ATTACH    | RO | <ul><li>USB device connection status bit of the port in</li><li>USB host mode:</li><li>1: The port has been connected to a USB device;</li><li>0: No USB device is connected to the port.</li></ul> | 0 |
|---|----------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 0 | bUMS_SPLIT_CAN | RO | In USB host mode, SPLIT packet transmission<br>permission bit:<br>1: Allow to transmit SPLIT packet;<br>0: Disable transmission.                                                                    | 0 |

# USB interrupt flag register (USBx\_INT\_FG) (x=0/1)

| Bit   | Name         | Access | Description                                                                                                                                                                                        | Reset<br>value |
|-------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:5] | Reserved     | RO     | Reserved.                                                                                                                                                                                          | 00b            |
| 4     | UIF_FIFO_OV  | RW1    | USB FIFO overflow interrupt flag bit, write 1<br>to clear it:<br>1: FIFO overflow trigger;<br>0: No event.                                                                                         | 0              |
| 3     | UIF_HST_SOF  | RW1    | <ul><li>SOF timing interrupt flag bit in USB host mode, cleared by writing 1:</li><li>1: SOF transmission completion trigger;</li><li>0: No event.</li></ul>                                       | 0              |
| 2     | UIF_SUSPEND  | RW1    | <ul><li>USB bus suspension or wake-up event interrupt flag bit, write 1 to clear it:</li><li>1: USB suspension event or wake-up event trigger;</li><li>0: No event.</li></ul>                      | 0              |
| 1     | UIF_TRANSFER | RW1    | <ul><li>USB transfer completion interrupt flag bit,<br/>write 1 to clear it:</li><li>1: A USB transmission completion trigger;</li><li>0: No event.</li></ul>                                      | 0              |
| 0     | UIF_DETECT   | RW1    | In USB host mode, USB device connection or<br>disconnection event interrupt flag bit, write 1 to<br>clear it:<br>1: USB device connection or disconnection<br>trigger is detected;<br>0: No event. | 0              |
| 0     | UIF_BUS_RST  | RW1    | <ul><li>USB bus reset event interrupt flag bit in USB device mode, write 1 to clear it:</li><li>1: USB bus reset event trigger;</li><li>0: No event.</li></ul>                                     | 0              |

### USB interrupt status register (USBx\_INT\_ST) (x=0/1)

| Bit | Name        | Access | Description                                                                                                                  | Reset<br>value |
|-----|-------------|--------|------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | bUIS_IS_NAK | RO     | In USB device mode, NAK response status bit:<br>1: Respond to NAK during current USB<br>transmission;<br>0: No NAK response. | 0              |

| 6     | bUIS_TOG_OK    | RO | CurrentUSBtransmissionDATA0/1synchronization flag match status bit:1: Synchronous;0: Asynchronous.                                                                                            | 0     |
|-------|----------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| [5:4] | MASK_UIS_TOKEN | RO | In device mode, the token PID of the current USB transfer transaction.                                                                                                                        | xxb   |
| [3:0] | MASK_UIS_ENDP  | RO | In device mode, the endpoint number of the current USB transfer transaction.                                                                                                                  | xxxxb |
| [3:0] | MASK_UIS_H_RES | RO | In host mode, respond PID identification of the<br>current USB transmission transaction. 0000<br>indicates that device has no response or<br>timeout. Other values indicate that respond PID. | xxxxb |

MASK\_UIS\_TOKEN is used to identify the token PID of the current USB transmission transaction in USB device mode: 00 means OUT packet; 01 means SOF packet; 10 means IN packet; 11 means SETUP packet.

MASK\_UIS\_H\_RES is only valid in host mode. In host mode, if the host transmits OUT/SETUP token packet, the PID is the handshake packet ACK/NAK/STALL/NYET, or the device has no response/timeout. If the host transmits IN token packet, the PID is the PID of the data packet (DATA0/DATA1/DATA2/MDATA) or the handshake packet PID.

#### USB receive length register (USBx RX LEN) (x=0/1)

| Bit    | Name       | Access | Description                                                                                                                              | Reset<br>value |
|--------|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | USB_RX_LEN | RO     | Current count of data received by the USB<br>endpoint, among which the lower 11 bits are<br>valid, and the higher 5 bits are fixed to 0. | xxxxh          |

#### **11.2.2 Device Register Description**

In USB device mode, each USB device controller of CH567 is equipped with 5 groups of bidirectional endpoints 0, 1, 2, 3, 4. The maximum data packet length of all endpoints except endpoint 0 is 512 bytes, and the maximum data packet length of endpoint 0 is 64 bytes.

Endpoint 0 is the default endpoint and supports control transmission. Transmission and reception share a 64-byte data buffer area.

Endpoint 1, endpoint 2, endpoint 3 each includes a transmission endpoint IN and a reception endpoint OUT. The transmission and reception each has a separate 512-byte or double 512-byte data buffer, support batch transmission, interrupt transmission, and real-time/synchronous transmission.

Endpoint 4 includes a transmission endpoint IN and a reception endpoint OUT. The transmission and reception each has a separate 512-byte data buffer, support batch transmission, interrupt transmission, and real-time/synchronous transmission.

Endpoint 0/1/2/3 can all set the UEPn\_DMAx register to configure their DMA address respectively. Set the endpoint receive/transmit data buffer mode through UEP4 1 MODx and UEP2 3 MODx registers.

Each group of endpoints are equipped with receive/transmit control register UEPn\_TX\_CTRLx and UEPn\_RX\_CTRLx and transmit length register UEPn\_T\_LENx (n=0/1/2/3/4), which are used to set the synchronization trigger bit of this endpoint, the response to OUT transactions and IN transactions and the length of data to be sent.

As the necessary USB bus pull-up resistor of USB device, it can be set whether to be enabled by software at any time. When bUC\_DEV\_EN in USB control register USBx\_CTRL is set to 1, the chip will set according to the speed of bUC\_SPEED\_TYPE, internally connect the pull-up resistor with the DP/DM pin of the USB bus and enable the USB device function.

When a USB bus reset, USB bus suspend or wake-up event is detected, or when the USB successfully processes data transmission or reception, the USB protocol processor will set corresponding interrupt flag. If the interrupt enable is switched on, the corresponding interrupt request will be also generated. The application program can directly query or query and analyze the interrupt flag register USBx INT FG in the USB interrupt service program, and perform corresponding processing according to UIF BUS RST and UIF SUSPEND. In addition, if UIF TRANSFER is valid, it is required to continue to analyze the USB interrupt status register USBx INT ST, and perform the corresponding processing according to the current endpoint number MASK\_UIS\_ENDP and the current transaction token PID identification MASK UIS TOKEN. If the synchronization trigger bit bUEP R TOG of OUT transaction of each endpoint is set in advance, you can judge whether the synchronization trigger bit of the data packet received matches the synchronization trigger bit of the endpoint through bUIS TOG OK. If the data is synchronized, the data is valid. If the data is not synchronized, the data should be discarded. After the USB transmission or reception interrupt is processed each time, the synchronization trigger bit of corresponding endpoint should be modified correctly to synchronize the data packet sent next time and detect whether the data packet received next time is synchronized. In addition, bUEP AUTO TOG can be set to automatically flip the corresponding synchronization trigger bit after successful transmission or reception.

The data to be sent by each endpoint is in their own buffer, and the length of the data to be sent is independently set in UEPn\_T\_LENx, and the length of one packet transmitted cannot exceed 512 bytes. The data received by each endpoint is in their own buffer, but the length of the data received is in the USB receive length register USBx\_RX\_LEN, and it can be distinguished according to the current endpoint number when the USB receives an interrupt. The maximum packet length that can be received by each endpoint needs to be written into the UEPn MAX LENx register in advance.

| Name          | Offset address | Description                               | Reset value |
|---------------|----------------|-------------------------------------------|-------------|
| UEP4_1_MODx   | 10h            | Mode control register of endpoint 1/4     | 8h00        |
| UEP2_3_MODx   | 11h            | Mode control register of endpoint 2/3     | 8h00        |
| UEP0_DMAx     | 14h            | Start address of endpoint 0 buffer        | 16hxxxx     |
| UEP1_DMAx     | 18h            | Start address of endpoint 1 buffer        | 16hxxxx     |
| UEP2_DMAx     | 1Ch            | Start address of endpoint 2 buffer        | 16hxxxx     |
| UEP3_DMA      | 20h            | Start address of endpoint 3 buffer        | 16hxxxx     |
| UEP0_MAX_LENx | 24h            | Endpoint 0 maximum length packet register | 16hxxxx     |
| UEP1_MAX_LENx | 28h            | Endpoint 1 maximum length packet register | 16hxxxx     |
| UEP2_MAX_LENx | 2Ch            | Endpoint 2 maximum length packet register | 16hxxxx     |
| UEP3_MAX_LENx | 30h            | Endpoint 3 maximum length packet register | 16hxxxx     |
| UEP4_MAX_LENx | 34h            | Endpoint 4 maximum length packet register | 16hxxxx     |
| UEP0_T_LENx   | 38h            | Endpoint 0 transmit length register       | 16hxxxx     |
| UEP0_TX_CTRLx | 3Ah            | Endpoint 0 transmit control register      | 8h00        |
| UEP0_RX_CTRLx | 3Bh            | Endpoint 0 receive control register       | 8h00        |
| UEP1_T_LENx   | 3Ch            | Endpoint 1 transmit length register       | 16hxxxx     |
| UEP1_TX_CTRLx | 3Eh            | Endpoint 1 transmit control register      | 8h00        |
| UEP1_RX_CTRLx | 3Fh            | Endpoint 1 receive control register       | 8h00        |
| UEP2_T_LENx   | 40h            | Endpoint 2 transmit length register       | 16hxxxx     |
| UEP2_TX_CTRLx | 42h            | Endpoint 2 transmit control register      | 8h00        |
| UEP2_RX_CTRLx | 43h            | Endpoint 2 receive control register       | 8h00        |
| UEP3_T_LENx   | 44h            | Endpoint 3 transmit length register       | 16hxxxx     |
| UEP3_TX_CTRLx | 46h            | Endpoint 3 transmit control register      | 8h00        |
| UEP3_RX_CTRLx | 47h            | Endpoint 3 receive control register       | 8h00        |
| UEP4_T_LENx   | 48h            | Endpoint 4 transmit length register       | 16hxxxx     |

Table 11-2 List of USB Device Registers

| UEP4_TX_CTRLx | 4Ah | Endpoint 4 transmit control register | 8h00 |
|---------------|-----|--------------------------------------|------|
| UEP4_RX_CTRLx | 4Bh | Endpoint 4 receive control register  | 8h00 |

Mode control register of USB endpoint 1/4 (UEP4\_1\_MODx) (x=0/1)

| Bit   | Name          | Access | Description                                                                                              | Reset<br>value |
|-------|---------------|--------|----------------------------------------------------------------------------------------------------------|----------------|
| 7     | bUEP1_RX_EN   | RW     | <ol> <li>1: Enable endpoint 1 reception (OUT);</li> <li>0: Disable endpoint 1 reception.</li> </ol>      | 0              |
| 6     | bUEP1_TX_EN   | RW     | 1: Enable endpoint 1 transmission (IN);<br>0: Disable endpoint 1 transmission.                           | 0              |
| 5     | Reserved      | RO     | Reserved.                                                                                                | 0              |
| 4     | bUEP1_BUF_MOD | RW     | Endpoint 1 data buffer mode control bit.                                                                 | 0              |
| 3     | bUEP4_RX_EN   | RW     | <ol> <li>1: Enable endpoint 4 reception (OUT);</li> <li>0: Disable endpoint 4 reception.</li> </ol>      | 0              |
| 2     | bUEP4_TX_EN   | RW     | <ol> <li>1: Enable endpoint 4 transmission (IN);</li> <li>0: Disable endpoint 4 transmission.</li> </ol> | 0              |
| [1:0] | Reserved      | RO     | Reserved.                                                                                                | 0              |

The data buffer modes of USB endpoint 0/4 are configured by a combination of bUEP4\_RX\_EN and bUEP4\_TX\_EN. Refer to the following table for the details:

|             |             | Table 11-5 Endpoint 0/4 Dunet Wode                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bUEP4_RX_EN | bUEP4_TX_EN | Description: arrange from low to high with UEP0_DMA as start address                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0           | 0           | Endpoint 0 single 64-byte transmit/receive shared buffer (IN and OUT), and endpoint 4 is disabled for transceiving.                                                                                                                                                                                                                                                                                                                                                            |
| 1           | 0           | Endpoint 0 single 64-byte transmit/receive shared buffer; endpoint 4 single 512-byte receive buffer (OUT).                                                                                                                                                                                                                                                                                                                                                                     |
| 0           | 1           | Endpoint 0 single 64-byte transmit/receive shared buffer; endpoint 4 single 512-byte transmit buffer (IN).                                                                                                                                                                                                                                                                                                                                                                     |
| 1           | 1           | Endpoint 0 single 64-byte transmit/receive shared buffers; endpoint 4<br>single 512-byte receive buffer (OUT);<br>Endpoint 4 single 512-byte receive buffer (IN). All 1088 bytes are<br>arranged as follows:<br>UEP0_DMA+0 address: 64-byte start address of endpoint 0<br>transmi/receive shared buffer;<br>UEP0_DMA+64 address: 512-byte start address of endpoint 4 receive<br>buffer;<br>UEP1_DMA+64+512 address: 512-byte start address of endpoint 4<br>transmit buffer. |

Table 11-3 Endpoint 0/4 Buffer Mode

#### USB endpoint 2/3 mode control register (UEP2\_3\_MODx) (x=0/1)

| Bit | Name          | Access | Description                                                                                              | Reset<br>value |
|-----|---------------|--------|----------------------------------------------------------------------------------------------------------|----------------|
| 7   | bUEP3_RX_EN   | RW     | <ol> <li>1: Enable endpoint 3 reception (OUT);</li> <li>0: Disable endpoint 3 reception.</li> </ol>      | 0              |
| 6   | bUEP3_TX_EN   | RW     | <ol> <li>1: Enable endpoint 3 transmission (IN);</li> <li>0: Disable endpoint 3 transmission.</li> </ol> | 0              |
| 5   | Reserved      | RO     | Reserved.                                                                                                | 0              |
| 4   | bUEP3_BUF_MOD | RW     | Endpoint 3 data buffer mode control bit.                                                                 | 0              |
| 3   | bUEP2_RX_EN   | RW     | 1: Enable endpoint 2 reception (OUT);                                                                    | 0              |

|   |               |    | 0: Disable endpoint 2 reception.                                               |   |
|---|---------------|----|--------------------------------------------------------------------------------|---|
| 2 | bUEP2_TX_EN   | RW | 1: Enable endpoint 2 transmission (IN);<br>0: Disable endpoint 2 transmission. | 0 |
| 1 | Reserved      | RO | Reserved.                                                                      | 0 |
| 0 | bUEP2_BUF_MOD | RW | Endpoint 2 data buffer mode control bit.                                       | 0 |

The data buffer modes of USB endpoint 1/2/3 are controlled by a combination of bUEPn\_RX\_EN, bUEPn\_TX\_EN and bUEPn\_BUF\_MOD (n=1/2/3) respectively, refer to the following table for details. Among them, in the double 512-byte buffer mode, the first 512-byte buffer will be selected based on bUEP\_\*\_TOG=0 and the last 512-byte buffer will be selected based on bUEP\_\*\_TOG=1 during USB data transmission, and bUEP\_AUTO\_TOG=1 is set to realize automatic switch.

| Table $11_4$ | Endpoint n | Buffer Mode | (n=1/2/3) |
|--------------|------------|-------------|-----------|
| 1able 11-4   | Endpoint n | Buller Mode | (n-1/2/3) |

|             | 14010       | 711-4 Endpoint II Buile | n mode (n 172/3)                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|-------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bUEPn_RX_EN | bUEPn_TX_EN | bUEPn_BUF_MOD           | Description: arrange from low to high with<br>UEPn_DMA as start address                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0           | 0           | Х                       | Endpoint is disabled, and the UEPn_DMA buffer is not used.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1           | 0           | 0                       | Single 512-byte receive buffer (OUT).                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1           | 0           | 1                       | Double 512-byte receive buffer (OUT), selected by bUEP R TOG.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0           | 1           | 0                       | Single 512-byte transmit buffer (IN).                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0           | 1           | 1                       | Double 512-byte transmit buffer (IN), selected by bUEP_T_TOG.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1           | 1           | 0                       | Single 512-byte receive buffer (OUT), and single 512-byte transmit buffer (IN).                                                                                                                                                                                                                                                                                                                                                                                                |
| 1           | 1           | 1                       | Double 512-byte receive buffer (OUT),<br>selected by bUEP_R_TOG.<br>Double 512-byte transmit buffer (IN), selected<br>by bUEP_T_TOG. All 2K bytes are arranged as<br>follows:<br>UEPn_DMA+0 address: Endpoint receive<br>address when bUEP_R_TOG=0;<br>UEPn_DMA+512 address: Endpoint receive<br>address when bUEP_R_TOG=1;<br>UEPn_DMA+1024 address: Endpoint tranmit<br>address when bUEP_T_TOG=0;<br>UEPn_DMA+1536 address: Endpoint transmit<br>address when bUEP_T_TOG=1. |

#### Start address of USB endpoint n buffer (UEPn\_DMAx)(n=1/2/3) (x=0/1)

| Bit    | Name     | Access | Description                                                                                                                      | Reset<br>value |
|--------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | UEPn_DMA | RW     | Start address of endpoint n buffer, the lowest 2 bits are fixed to 0 (4 bytes are aligned), and the highest 1 bit is fixed to 0. | xxxxh          |

#### Endpoint n maximum length packet register (UEPn\_MAX\_LENx) (n=1/2/3) (x=0/1)

| Bit    | Name         | Access | Description                               | Reset<br>value |
|--------|--------------|--------|-------------------------------------------|----------------|
| [15:0] | UEPn_MAX_LEN | RW     | Maximum packet length of data received by | xxxxh          |

| endpoint n. |  |
|-------------|--|
|-------------|--|

Note: This maximum packet length determines the maximum length of data that can be received by the endpoint. The data beyond this length will be discarded and DMA will not transmit it to the customized zone.

Endpoint n transmit length register (UEPn\_T\_LENx) (x=0/1)

| Bit    | Name       | Access | Description                                                                                                                                                    | Reset<br>value |
|--------|------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | UEPn_T_LEN | RW     | Set the number of bytes of data to be sent by USB endpoint n, the lower 10 bits are valid, and the higher 6 bits are fixed to 0, with a maximum length of 512. | xxxxh          |

### Endpoint n transmit control register (UEPn\_TX\_CTRLx) (x=0/1)

| Bit   | Name           | Access | Description                                                                                                                                                                                                                                                                                                                                                                 | Reset<br>value |
|-------|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:6] | Reserved       | RO     | Reserved                                                                                                                                                                                                                                                                                                                                                                    | 0              |
| 5     | bUEP_AUTO_TOG  | RW     | Synchronization trigger bit auto flip enable<br>control bit:<br>1: After the data is successfully transmitted, the<br>corresponding synchronization trigger bit is<br>automatically flipped;<br>0: Not flipped automatically, but can be<br>switched manually.<br>Only endpoint 1/2/3 supports, and<br>real-time/synchronous transmission can only<br>be switched manually. | 0              |
| [4:3] | MASK_UEP_T_TOG | RW     | Synchronization trigger bit of the transmitter<br>(processing IN transactions) of USB endpoint n<br>00: Transmit DATA0;<br>01: Transmit DATA1;<br>10: Transmit DATA2;<br>11: Transmit MDATA.                                                                                                                                                                                | 0              |
| 2     | bUEP_T_RES_NO  | RW     | <ol> <li>No expected response, used to achieve<br/>real-time/synchronous transmission of<br/>non-endpoint 0. Ignore MASK_UEP_T_RES<br/>at this time;</li> <li>0: Expected response.</li> </ol>                                                                                                                                                                              | 0              |
| [1:0] | MASK_UEP_T_RES | RW     | Response control from endpoint n to IN<br>transactions:<br>00: Data is ready and ACK is expected;<br>10: Response NAK or busy;<br>11: Response STALL or error.                                                                                                                                                                                                              | 0              |

#### Endpoint n receive control register (UEPn\_RX\_CTRLx) (x=0/1)

| Bit   | Name     | Access | Description | Reset<br>value |
|-------|----------|--------|-------------|----------------|
| [7:6] | Reserved | RO     | Reserved    | 0              |

| 5     | bUEP_AUTO_TOG  | RW | Synchronization trigger bit auto flip enable<br>control bit:<br>1: After the data is successfully received, the<br>corresponding synchronization trigger bit is<br>automatically flipped;<br>0: It is not flipped automatically, but can be<br>switched manually.<br>Only endpoint 1/2/3 supports, and<br>real-time/synchronous transmission can only<br>be switched manually. | 0 |
|-------|----------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [4:3] | MASK_UEP_R_TOG | RW | Expected synchronization trigger bit of the<br>receiver (processing OUT transactions) of USB<br>endpoint n:<br>00: Expected DATA0;<br>01: Expected DATA1;<br>10: Expected DATA2;<br>11: Expected MDATA.<br>It is invalid for real-time/synchronous<br>transmission.                                                                                                            | 0 |
| 2     | bUEP_R_RES_NO  | RW | <ul> <li>1: No expected response, used to achieve real-time/synchronous transmission of non-endpoint 0. Ignore MASK_UEP_R_RES at this time;</li> <li>0: Expected response.</li> </ul>                                                                                                                                                                                          | 0 |
| [1:0] | MASK_UEP_R_RES | RW | Control of response from the receiver of USB<br>endpoint n to OUT transactions:<br>00: Response ACK; -<br>10: Response NAK or busy;<br>11: Response STALL or error;<br>01: Response to NYET.<br>It is invalid for real-time/synchronous<br>transmission.                                                                                                                       | 0 |

### 11.2.3 USB Host Register

In USB host mode, each host controller of CH567 is equipped with 1 set of bidirectional host endpoints, including a transmit endpoint OUT and a receive endpoint IN. The maximum data packet length is 512 bytes, they support control transmission, interrupt transmission, batch transmission and real-time/synchronous transmission.

Each USB transaction initiated by host endpoint always automatically sets the interrupt flag UIF\_TRANSFER after processing. The application program can directly query or query and analyze the interrupt flag register USB\_INT\_FG in the USB interrupt service program, and perform corresponding processing according to each interrupt flag. In addition, if UIF\_TRANSFER is valid, it is required to continue to analyze the USB interrupt status register USBx\_INT\_ST, and perform the corresponding processing according to the response PID identification MASK\_UIS\_H\_RES of the current USB transmission transaction.

If the synchronization trigger bit bUH\_R\_TOG of IN transaction of host receive endpoint is set in advance, you can judge whether the synchronization trigger bit of the data packet received matches the synchronization trigger bit of the endpoint through bUIS\_TOG\_OK. If the data is synchronized, the data is valid. If the data is not synchronized, the data should be discarded. After the USB transmit or receive

interrupt is processed each time, the synchronization trigger bit of corresponding host endpoint should be modified correctly to synchronize the data packet sent next time and detect whether the data packet received next time is synchronized. In addition, bUEP\_AUTO\_TOG can be set to automatically flip the corresponding synchronization trigger bit after successful transmission or reception.

73

USB host token setting register UH\_EP\_PID is used to set the endpoint number of the target device being operated and the token PID packet identification of the USB transmission transaction. The data corresponding to the SETUP token and OUT token is provided by the host transmit endpoint. The data to be transmitted is in the UH\_TX\_DMAx buffer, and the length of the data to be transmitted is set in UH\_TX\_LENx. The data corresponding to the IN token is returned by the target device to the host receive endpoint, the received data is stored in the UH\_RX\_DMAx buffer, and the received data length is stored in USBx\_RX\_LEN. The maximum packet length that can be received by the host endpoint needs to be written to the UH\_RX\_MAX\_LENx register in advance.

| Name            | Offset address | Description                                 | Reset value |
|-----------------|----------------|---------------------------------------------|-------------|
| UHOST_CTRLx     | 01h            | USB host control register                   | 8h00        |
| UH_EP_MODx      | 11h            | USB host endpoint mode control register     | 8h00        |
| UH_RX_DMAx      | 1Ch            | USB host receive buffer area start address  | 16hxxxx     |
| UH_TX_DMAx      | 20h            | USB host transmit buffer area start address | 16hxxxx     |
| UH RX MAX LENx  | 2Ch            | USB host receive maximum length packet      | 16hxxxx     |
| OII_KA_MAA_LENX |                | register                                    | 10112222    |
| UH_SETUPx       | 3Eh            | USB host auxiliary setting register         | 8h00        |
| UH_EP_PIDx      | 40h            | USB host token setting register             | 8h00        |
| UH_RX_CTRLx     | 43h            | USB host receive endpoint control register  | 8h00        |
| UH_TX_LENx      | 44h            | USB host transmit length register           | 16hxxxx     |
| UH_TX_CTRLx     | 46h            | USB host transmit endpoint control register | 8h00        |
| UH_SPLIT_DATAx  | 48h            | USB host transmit SPLIT packet data         | 16hxxxx     |

Table 11-5 List of USB Host Related Registers

USB host control register (UHOST\_CTRLx) (x=0/1)

| Bit   | Name               | Access | Description                                 | Reset<br>value |
|-------|--------------------|--------|---------------------------------------------|----------------|
| [7:3] | Reserved           | RO     | Reserved.                                   | 0              |
| 2     | bUH_TX_BUS_RESUME  | RW     | In host mode, the host wakes up the device. | 0              |
| 1     | bUH_TX_BUS_SUSPEND | RW     | USB host transmit suspend signal.           | 0              |
| 0     | bUH_TX_BUS_RESET   | RW     | USB host transmit bus reset signal.         | 0              |

Note: The suspend and reset time is determined by the hold time of high-level bUH\_TX\_BUS\_SUSPEND and bUH\_TX\_BUS\_RESET. If the host wakes up the device, it is determined by the edge method of bUH\_TX\_BUS\_RESUME, so it is only required to pull bUH\_TX\_BUS\_RESUME up and then down for wake-up.

USB host endpoint mode control register (UH\_EP\_MODx) (x=0/1)

| Bit | Name         | Access | Description                                                                                                                         | Reset<br>value |
|-----|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7   | Reserved     | RO     | Reserved                                                                                                                            | 0              |
| 6   | bUH_EP_TX_EN | RW     | Host transmit endpoint transmit<br>(SETUP/OUT) enable bit:<br>1: Enable endpoint transmission;<br>0: Disable endpoint transmission. | 0              |

| 5     | Reserved        | RO | Reserved.                                                                                                                                     | 0   |
|-------|-----------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 4     | bUH_EP_TBUF_MOD | RW | Host transmit endpoint transmitg data buffer mode control bit.                                                                                | 0   |
| 3     | bUH_EP_RX_EN    | RW | <ul><li>Host receive endpoint receive (IN) enable bit:</li><li>1: Enable endpoint reception;</li><li>0: Disable endpoint reception.</li></ul> | 0   |
| [2:1] | Reserved        | RO | Reserved.                                                                                                                                     | 00b |
| 0     | bUH_EP_RBUF_MOD | RW | USB host receive endpoint data buffer area mode control bit.                                                                                  | 0   |

The data buffer modes of USB host transmit endpoint are controlled by a combination of bUH\_EP\_TX\_EN and bUH\_EP\_TBUF\_MOD, refer to the following table.

| Table 11-6 Host tra | nsmit buffer Mode |
|---------------------|-------------------|
|---------------------|-------------------|

| bUH_EP_TX_EN | bUH_EP_TBUF_MOD | Description: Take UH_TX_DMA as start address                                                                                                                                            |
|--------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0            | Х               | Endpoint is disabled, and UH_TX_DMA buffer is not used.                                                                                                                                 |
| 1            | 0               | Single 512-byte transmit buffer (SETUP/OUT).                                                                                                                                            |
| 1            | 1               | Double 512-byte transmit buffer, selected by bUH_T_TOG:<br>When bUH_T_TOG=0, select the first 512 bytes of the<br>buffer;<br>When bUH_T_TOG=1, select the last 512 bytes of the buffer. |

The data buffer modes of USB host receive endpoint are controlled by a combination of

| bUH EP RX | EN and bUH E | EP RBUF N | MOD, refer to the | following table. |
|-----------|--------------|-----------|-------------------|------------------|
|           |              |           |                   |                  |

| Table 11-7 Host receive buffer Mode                        |                 |                                                        |  |  |  |
|------------------------------------------------------------|-----------------|--------------------------------------------------------|--|--|--|
| bUH_EP_RX_EN                                               | bUH_EP_RBUF_MOD | Description: Take UH_TX_DMA as start address           |  |  |  |
| 0 x Endpoint is disabled, and UH_RX_DMA buffer is not used |                 |                                                        |  |  |  |
| 10Single 512-byte receive buffer (IN).                     |                 |                                                        |  |  |  |
|                                                            |                 | Double 512-byte receive buffer, selected by bUH_R_TOG: |  |  |  |
|                                                            |                 | When bUH_R_TOG=0, select the first 512 bytes of the    |  |  |  |
| 1                                                          | 1               | buffer;                                                |  |  |  |
|                                                            |                 | When bUH_R_TOG=1, select the last 512 bytes of the     |  |  |  |
|                                                            |                 | buffer.                                                |  |  |  |

Start address of USB host receive buffer (UH\_RX\_DMAx) (x=0/1)

| Bit    | Name      | Access | Description                                                                                                                                               | Reset<br>value |
|--------|-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | UH_RX_DMA | RW     | Start address of host endpoint data receive<br>buffer, the lowest 2 bits are fixed to 0 (4<br>bytes are aligned), and the highest 1 bit is<br>fixed to 0. | xxxxh          |

### Start address of USB host transmit buffer (UH\_TX\_DMAx) (x=0/1)

| Bit    | Name      | Access | Description                                                                                                                                                | Reset<br>value |
|--------|-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | UH_TX_DMA | RW     | Start address of host endpoint data transmit<br>buffer, the lowest 2 bits are fixed to 0 (4<br>bytes are aligned), and the highest 1 bit is<br>fixed to 0. | xxxxh          |

### USB host receive maximum length packet register (UH\_RX\_MAX\_LENx) (x=0/1)

| Bit    | Name          | Access | Description                                                  | Reset<br>value |
|--------|---------------|--------|--------------------------------------------------------------|----------------|
| [15:0] | UH_RX_MAX_LEN | RW     | Maximum packet length of data received by the host endpoint. | xxxxh          |

Note: This maximum packet size determines the maximum length of data that can be received by the endpoint. The data beyond this length will be discarded and DMA will send it to the customized zone.

## USB host auxiliary device register (UH\_SETUPx) (x=0/1)

| Bit   | Name       | Access | Description                                                                                                                                    | Reset<br>value |
|-------|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7     | Reserved   | RO     | Reserved.                                                                                                                                      | 0              |
| 6     | bUH_SOF_EN | WO     | Automatical generate SOF packet enable<br>control bit:<br>1: The host automatically generates SOF<br>packet;<br>0: No SOF packet is generated. | 0              |
| [5:0] | Reserved   | RO     | Reserved.                                                                                                                                      | 00             |

## USB host token setting register (UH\_EP\_PIDx) (x=0/1)

| Bit   | Name          | Access | Description                                                                   | Reset<br>value |
|-------|---------------|--------|-------------------------------------------------------------------------------|----------------|
| [7:4] | MASK_UH_TOKEN | RW     | Set the token PID packet identification of this USB transmission transaction. | 0000Ъ          |
| [3:0] | MASK_UH_ENDP  | RW     | Set the endpoint number of the target device<br>being operated this time.     | 0000Ь          |

## USB host receive endpoint control register (UH\_RX\_CTRLx) (x=0/1)

| Bit   | Name           | Access | Description                                                                                                                                                                                                                                                                | Reset<br>value |
|-------|----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7     | Reserved       | RO     | Reserved.                                                                                                                                                                                                                                                                  | 0b             |
| 6     | bUH_R_DATA_NO  | RW     | <ol> <li>Data packet is not expected, used for<br/>high-speed HUB operation in host mode;</li> <li>Data packet expected (IN).</li> </ol>                                                                                                                                   | 0              |
| 5     | bUH_R_AUTO_TOG | RW     | Synchronization trigger bit auto flip enable<br>control bit:<br>1: After the data is successfully received, the<br>corresponding expected synchronization<br>trigger bit is automatically flipped;<br>0: It is not flipped automatically, but can be<br>switched manually. | 0              |
| [4:3] | MASK_UH_R_TOG  | RW     | Synchronization trigger bit expected by the<br>host receiver (processing IN transactions),<br>00: Expected DATA0;<br>01: Expected DATA1;<br>10: Expected DATA2;<br>11: Expected MDATA.                                                                                     | 0              |
| 2     | bUH_R_RES_NO   | RW     | 1: No response, used to achieve                                                                                                                                                                                                                                            | 0              |

|       |               |    | real-time/synchronous transmission of<br>non-endpoint 0. Ignore MASK_UEP_R_RES<br>at this time;<br>0: Transmit response after data is received<br>successfully. |     |
|-------|---------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| [1:0] | MASK_UH_R_RES | RW | Control on response from the receiver of host<br>to IN transactions:<br>00: Response ACK; -<br>It is invalid for real-time/synchronous<br>transmission.         | 00ь |

## USB host transmit length register (UH\_TX\_LENx) (x=0/1)

| Bit    | Name        | Access | Description                                                                                                                                                | Reset<br>value |
|--------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | UH_TX_LEN_H | RW     | Set the number of bytes of data to be sent by<br>USB host transmiy endpoint, only the lower<br>11 bits are valid, and the higher 5 bits are<br>fixed to 0. | xxxxh          |

## USB host transmit endpoint control register (UH\_TX\_CTRLx) (x=0/1)

| Bit   | Name           | Access | Description                                                                                                                                                                                                                                                                              | Reset<br>value |
|-------|----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 7     | Reserved       | RO     | Reserved.                                                                                                                                                                                                                                                                                | 0b             |
| 6     | bUH_T_DATA_NO  | RW     | <ol> <li>No data packet is sent (PING/SPLIT);</li> <li>Send data packet (OUT/SETUP).</li> </ol>                                                                                                                                                                                          | 0              |
| 5     | bUH_T_AUTO_TOG | RW     | <ul> <li>Synchronization trigger bit auto flip enable control bit:</li> <li>1: After the data is successfully tranmistted, the corresponding synchronization trigger bit is automatically flipped;</li> <li>0: It is not flipped automatically, but can be switched manually.</li> </ul> | 0              |
| [4:3] | MASK_UH_T_TOG  | RW     | Synchronization trigger bit prepared by USB<br>host transmitter (processing SETUP/OUT<br>transactions)<br>00: Transmit DATA0;<br>01: Transmit DATA1;<br>10: Transmit DATA2;<br>11: Transmit MDATA.                                                                                       | 00Ъ            |
| 2     | bUH_T_RES_NO   | RW     | <ol> <li>No response, used to achieve<br/>real-time/synchronous transmission of<br/>non-endpoint 0. Ignore MASK_UEP_T_RES<br/>at this time;</li> <li>0: Expect response after data is transmitted<br/>successfully.</li> </ol>                                                           | 0              |
| [1:0] | MASK_UH_T_RES  | RW     | Response control bit from USB host<br>transmitter to SETUP/OUT transaction<br>00: Expected response ACK;<br>10: Expected response NAK or busy;                                                                                                                                           | 00Ь            |

| 11: Expected response STALL or error;   |
|-----------------------------------------|
| 01: Expected response to NYET.          |
| It is invalid for real-time/synchronous |
| transmission.                           |

Data of SPLIT packet sent by USB host (UH SPLIT DATAx) (x=0/1)

| Bit    | Name          | Access | Description                                                                                                                                  | Reset<br>value |
|--------|---------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:0] | UH_SPLIT_DATA | RW     | Data content of SPLIT packet sent by the<br>host endpoint, among which the lower 12 bits<br>are valid, and the higher 4 bits are fixed to 0. | 0xxxh          |

## **11.3 USB Device Mode Configuration**

## **11.3.1 Basic Initial Configuration**

1. Set bUC\_HOST\_MODE bit of USBx\_CTRL register to 0, to configure USB device mode;

2. Set USBx\_CTRL register, clear bUC\_RESET\_SIE and bUC\_CLR\_ALL bits to 0, set bUC\_INT\_BUSY and bUC\_DMA\_EN bits to 1, configure UC\_SPEED\_TYPE to select the speed of USB device. If it is set as a high-speed device, but the current host is at full speed, the controller will automatically slow down and switch to full speed, and the actual communication speed can be queried in the USBx\_SPEED\_TYPE register.

3. Clear the device address register USBx\_DEV\_AD and interrupt flag register USBx\_INT\_FG. Optional operation, enable the required interrupt, and write USBx\_INT\_EN register;

4. Configure the device endpoint data transceiver buffer mode register UEP4\_1\_MODx/ UEP2\_3\_MODx, and the transceiver control register UEPn\_TX\_CTRLx/ UEPn\_RX\_CTRLx;

5. Set the endpoint maximum packet receive length UEPn\_MAX\_LENx register and the endpoint data transceiver start address UEPn\_DMAx;

6. Set bUC\_DEV\_PU\_EN bit of USBx\_CTRL register to 1, to enable USB device function.

## **11.4 USB Host Mode Configuration**

### **11.4.1 Basic Initial Configuration**

1. Set bUC\_HOST\_MODE bit of USBx\_CTRL register to 1, to configure USB host mode;

2. Set the USBx\_CTRL register, clear bUC\_RESET\_SIE and bUC\_CLR\_ALL bits to 0, set bUC\_INT\_BUSY and bUC\_DMA\_EN bits to 1, configure UC\_SPEED\_TYPE to select the speed of USB device. If it is set as a high-speed device, but the current connecting device is at full speed, the controller will automatically slow down and switch to full speed, and the actual communication speed can be queried in the USBx\_SPEED\_TYPE register.

3. Clear the device address register USBx\_DEV\_AD and interrupt flag register USBx\_INT\_FG. Optional operation, enable the required interrupt, and write USBx\_INT\_EN register;

4. Configure the host endpoint data transceiver buffer mode register UH\_EP\_MODx, and the transceiver control register UH\_RX\_CTRLx/UH\_TX\_CTRLx;

5. Set the host endpoint maximum packet receiving length UH\_RX\_MAX\_LENx register and the host endpoint data transceiver start address register UH\_RX\_DMAx / UH\_TX\_DMAx;

6. Set the bUH\_SOF\_EN bit of UH\_SETUPx register to 1, to enable the port to automatically transmit SOF packets.

# Chapter 12 SD Controller and AES/SM4 Module

## 12.1 Introduction to SD Controller and AES/SM4 Module

CH567 chip is equipped with 4 independent SD controllers: SD0, SD1, SD2 and SD3. Compared with common controllers, they are provided with additional encryption/decryption algorithm module support, which can meet the data security requirements of the market.

The main features are as follows:

1) Support SD physical layer 1.0 and 2.0 specifications, support UHS-I SDR50 mode (forward compatible) of SD3.0 specifications;

2) Conform to 4.4 and 4.5.1 specifications of eMMC card, and compatible with 5.0 specifications and HS200 mode;

3) 4 controllers all support the single-wire and four-wire mode of eMMC card, and SD0 and SD2 support the single-wire, four-wire and eight-wire mode of eMMC card;

4) Support SD card, SDIO card, eMMC card and other devices that comply with SD protocol;

5) Support SD interface data for AES and SM4 algorithm encryption and decryption;

6) The 4 controllers work independently, support DMA and interrupts.

## **12.2 SD Register Description**

CH567 is equipped with 4 independent SD controllers, and each controller has a similar control unit.

SD0 related register physical base address: 0x0040 A000

SD1 related register physical base address: 0x0040 A040

SD2 related register physical base address: 0x0040 A080

SD3 related register physical base address: 0x0040 A0C0

| Name           | Offset address | Description                               | Reset value |
|----------------|----------------|-------------------------------------------|-------------|
| SD_CLK_CFG     | 3Ch            | Clock configuration register              | 16h0214     |
| SDx_ARGUMENT   | 00h            | Command parameter register                | 32h0000000  |
| SDx_CMD_SET    | 04h            | Command setting register                  | 16h0000     |
| SDx_RESPONSE0  | 08h            | Response parameter register 0             | 32h0000000  |
| SDx_RESPONSE1  | 0Ch            | Response parameter register 1             | 32h0000000  |
| SDx_RESPONSE2  | 10h            | Response parameter register 2             | 32h0000000  |
| SDx_RESPONSE3  | 14h            | Response parameter register 3             | 32h0000000  |
| SDx_WRITE_CONT | 14h            | Continue write start register             | 32h0000000  |
| SDx_CTRL       | 18h            | Control register                          | 8h15        |
| SDx_TOCNT      | 1Ch            | Timeout count register                    | 8h0C        |
| SDx_STATUS     | 20h            | Status register                           | 32h0000000  |
| SDx_INT_FG     | 24h            | Interrupt flag register                   | 16h0000     |
| SDx_INT_EN     | 28h            | Interrupt enable register                 | 16h0000     |
| SDx_DMA        | 2Ch            | DMA start address register                | 16hxxxx     |
| SDx_BLOCK_CFG  | 30h            | Transmission block configuration register | 32h00000000 |
| SDx_TRAN_MODE  | 34h,           | Transmission mode register                | 8h00        |

Table 12-1 List of SD Registers

Clock configuration register (SD\_CLK\_CFG)

|         |                 |    |                                                                                                                                                                                                                                                  | value |
|---------|-----------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| [16:10] | Reserved        | RO | Reserved.                                                                                                                                                                                                                                        | 00h   |
| 9       | bSDCLK_Mode     | WO | Clock frequency mode selection bit:<br>1: High-speed mode, 25M-100MHz;<br>0: Low-speed mode, 400KHz.                                                                                                                                             | 1     |
| 8       | bSDCLK_OE       | WO | <ul><li>SD physical clock signal line output control bit:</li><li>1: Turn on, output the communication clock;</li><li>0: Turn off.</li></ul>                                                                                                     | 0     |
| [7:5]   | Reserved        | RO | Reserved.                                                                                                                                                                                                                                        | 0     |
| [4:0]   | MASK_SD_CLK_PRE | WO | SD controller clock (SDCLK) division factor:<br>When bSDCLK_Mode=1, then<br>SDCLK = 480M/MASK_CLK_PRE;<br>When bSDCLK_Mode =0, then<br>SDCLK = 480M/MASK_CLK_PRE/64.<br>Writing 1 is equivalent to turning off the SDC<br>module sampling clock. | 14h   |

Note: The clock configured by clock configuration register (SD\_CLK\_CFG) is shared by 4 SD card controllers.

### Command parameter register (SDx\_ARGUMENT) (x=0/1/2/3)

| Bit    | Name        | Access | Description                                | Reset<br>value |
|--------|-------------|--------|--------------------------------------------|----------------|
| [31:0] | SD_ARGUMENT | RW     | SD/eMMC 32-bit command parameter register. | 0              |

## Command setting register (SDx\_CMD\_SET) (x=0/1/2/3)

| Bit     | Name           | Access | Description                                                                                                                                                                                           | Reset<br>value |
|---------|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:12] | Reserved       | RO     | Reserved.                                                                                                                                                                                             | 0              |
| 11      | bCHK_RESP_IDX  | RW     | Command index for check response:<br>1: Required;<br>0: Not required.                                                                                                                                 | 0              |
| 10      | bCHK_RESP_CRC  | RW     | CRC for check response:<br>1: Required;<br>0: Not required.                                                                                                                                           | 0              |
| [9:8]   | MASK_RESP_TYPE | RW     | Expected response type:<br>00b: No response;<br>01b: The response length is 136 bits;<br>10b: The response length is 48 bits;<br>11b: The response length is 48 bits, and it is<br>R1b type response. | 0              |
| [7:6]   | Reserved       | RO     | Reserved.                                                                                                                                                                                             | 0              |
| [5:0]   | MASK_CMD_IDX   | RW     | The index number of the command being sent currently.                                                                                                                                                 | 0              |

Response parameter register (SDx\_RESPONSE) (x=0/1/2/3)

| D:4 | Name | • • • • • • • | Description | Reset |  |
|-----|------|---------------|-------------|-------|--|
| Bit | Name | Access        | Description | value |  |

| [31:0]   | SDx_RESPONSE0  | RO | Response parameter register 0                                                                      | 0 |
|----------|----------------|----|----------------------------------------------------------------------------------------------------|---|
| [63:32]  | SDx_RESPONSE1  | RO | Response parameter register 1                                                                      | 0 |
| [95:64]  | SDx_RESPONSE2  | RO | Response parameter register 2                                                                      | 0 |
| [127:96] | SDx_RESPONSE3  | RO | Response parameter register 3                                                                      | 0 |
| [127:96] | SDx_WRITE_CONT | WO | Multiplexed SD_RESPONSE3 register, used to start write operation in the multi-block write process. | 0 |

Note: When the response length is 136 bits, the effective data is 128 bits. When the response length is 48 bits, the effective data length is 32 bits. The SDx\_RESPONSEx register is used to store the effective data parameters for response.

The SDx\_RESPONSE3 register is multiplexed. The multiplexing of the register is: operation of writing this register in the process of continuously writing multiple blocks of data to the card using the CMD25 command, when the block interrupt is completed, when it is not required to change DMA address, to start the operation of writing data to SD. To change DMA address, write DMA address register to start to write data to SD, and it is not needed to start it by writing register.

| Bit   | Name            | Access | Description                                                                                                                                                                                                                                                                                                                                                                | Reset<br>value |
|-------|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [7:6] | Reserved        | RO     | Reserved.                                                                                                                                                                                                                                                                                                                                                                  | 0              |
| 5     | bSC_NEG_SAMPLE  | RW     | <ul><li>Cmd and Data signal line sample mode selection bit:</li><li>1: Sample on the falling edge;</li><li>1: Sample on the rising edge.</li></ul>                                                                                                                                                                                                                         | 0              |
| 4     | bSC_RST_DAT_LGC | RW     | <ol> <li>Reset the internal data receive/transmit<br/>logic, which needs to be cleared by software;</li> <li>Work normally;</li> </ol>                                                                                                                                                                                                                                     | 1              |
| 3     | bSC_DMA_ENABLE  | RW     | <ul><li>DMA and DMA interrupt control bit of SD controller:</li><li>1: Enable DMA function and DMA interrupt;</li><li>0: Switch off DMA.</li></ul>                                                                                                                                                                                                                         | 0              |
| 2     | bSC_ALL_CLR     | RW     | <ol> <li>Reset SD controller logic, which needs to be<br/>cleared by software;</li> <li>Work normally;</li> </ol>                                                                                                                                                                                                                                                          | 1              |
| [1:0] | DAT_LINE_WIDTH  | RW     | Data line width sampled by receive/transmit<br>data logic (communication data line width):<br>00: The transceiver only uses dat[0], single<br>data line;<br>01: The transceiver uses dat[3:0], 4 data lines;<br>10: The transceiver uses dat[7:0], 8 data lines;<br>This value is only supported by the 0# and 2#<br>controllers and used for 8-wire mode of<br>eMMC card. | 01b            |

Control register (SDx\_CTRL) (x=0/1/2/3)

#### Timeout control register (SDx\_TOCNT) (x=0/1/2/3)

| Bit   | Name     | Access | Description | Reset<br>value |
|-------|----------|--------|-------------|----------------|
| [7:4] | Reserved | RO     | Reserved.   | 0              |

| [3:0] | MASK_TOCNT | RW | Response/data timeout configuration:<br>0: Disable the internal timeout mechanism;<br>Non-zero: Set the timeout time, and valid<br>values are 0-12.<br>Calculation method: SD card clock cycle *<br>4194304 * MASK_TOCNT.<br>For example: If SDCLK cycle is 10ns at this<br>time, write 12, and the timeout time is 10ns *<br>(4194304) * (12) = 503ms. | Ch |
|-------|------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|-------|------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|

Note: 1. The above data timeout includes the following 4 situations:

1) DAT[0] busy timeout after R1b response;

2) When writing a data block, DAT[0] busy timeout after CRC status;

3) When writing a data block, waiting for the CRC status timeout;

4) When reading a data block, waiting for the start bit timeout.

2. The command response also supports a timeout mechanism. If the response times out, it will be given by the SIF\_RE\_TMOUT interrupt in the interrupt register. The command timeout uses the maximum timeout value given by the protocol: 64 Tsdclk.

| Bit     | Name           | Access | Description                                                                                                                        | Reset<br>value |
|---------|----------------|--------|------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [32:18] | Reserved       | RO     | Reserved.                                                                                                                          | 0              |
| 17      | bST_DAT0_HI    | RO     | 1: The current DAT0 line is at high level<br>0: Low level.                                                                         | 0              |
| 16      | bST_CMD_HI     | RO     | 1: The current CMD line is at high level;<br>0: Low level.                                                                         | 0              |
| [15:0]  | MASK_BLOCK_NUM | RO     | It indicates the number of blocks that have<br>been successfully transmitted in the current<br>multi-block transmission operation. | 0              |

Status indication register (SDx STATUS) (x=0/1/2/3)

#### Interrupt flag register (SDx\_INT\_FG) (x=0/1/2/3)

| Bit     | Name           | Access | Description                                                                                                                                             | Reset<br>value |
|---------|----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [15:10] | Reserved       | RO     | Reserved.                                                                                                                                               | 0              |
| 9       | bSIF_SDIO_INT  | RW1    | <ul><li>SDIO card interrupt flag bit, write 1 to clear it:</li><li>1: SDIO card generates card interrupt;</li><li>0: No event.</li></ul>                | 0              |
| 8       | bSIF_FIFO_OF   | RW1    | <ul><li>FIFO overflow interrupt flag bit, write 1 to clear it:</li><li>1: FIFO overflow trigger;</li><li>0: No event.</li></ul>                         | 0              |
| 7       | bSIF_BLOCK_GAP | RW1    | Single block transmission completion flag bit,<br>write 1 to clear it:<br>1: Single block reception/transmission<br>completion trigger;<br>0: No event. | 0              |
| 6       | bSIF_TRANS_SC  | RW1    | Flag bit for completing transmitting the<br>number of requested blocks, write 1 to clear it:<br>1: The transmission of number of requested              | 0              |

|   |                |       | blocks completed trigger;                     |   |
|---|----------------|-------|-----------------------------------------------|---|
|   |                |       | 0: No event.                                  |   |
|   |                |       | Transmission CRC error flag bit, write 1 to   |   |
| 5 | LOIE TRANCER   | RW1   | clear it:                                     | 0 |
| 5 | bSIF_TRANS_ER  | K W I | 1: CRC error trigger;                         | 0 |
|   |                |       | 0: No event.                                  |   |
|   |                |       | Data timeout flag bit, write 1 to clear it:   |   |
| 4 | bSIF_DATA_TMO  | RW1   | 1: Data timeout trigger;                      | 0 |
|   |                |       | 0: No event.                                  |   |
|   |                |       | Command completion flag bit, write 1 to clear |   |
|   |                |       | it:                                           |   |
| 3 | bSIF_CMD_DONE  | RW1   | 1: Transmit command, and receive the          | 0 |
|   |                |       | completion of response;                       |   |
|   |                |       | 0: No event.                                  |   |
|   |                |       | Response index number check error flag bit,   |   |
| 2 | bSIF_RE_IDX_ER | RW    | write 1 to clear it:                          | 0 |
| 2 |                |       | 1: Response index number check error trigger; | 0 |
|   |                |       | 0: No event.                                  |   |
|   |                |       | Response CRC check error flag bit, write 1 to |   |
| 1 | bSIF RE CRC WR | RW    | clear it:                                     | 0 |
| 1 |                | IX W  | 1: Response CRC check error trigger;          | 0 |
|   |                |       | 0: No event.                                  |   |
|   |                |       | Receive response timeout flag bit, write 1 to |   |
| 0 | bSIF RE TMOUT  | RW    | clear it:                                     | 0 |
| U |                | 17.17 | 1: Data timeout trigger;                      | v |
|   |                |       | 0: No event.                                  |   |

## Interrupt enable register (SDx\_INT\_EN) (x=0/1/2/3)

| Bit     | Name           | Access | Description                             | Reset<br>value |
|---------|----------------|--------|-----------------------------------------|----------------|
| [15:10] | Reserved       | RO     | Reserved                                | 0              |
|         |                |        | SDIO card interrupt:                    |                |
| 9       | bSIE_SDIO_INT  | RW     | 1: Enable the corresponding interrupt;  | 0              |
|         |                |        | 0: Disable the corresponding interrupt. |                |
|         |                |        | FIFO overflow is interrupted:           |                |
| 8       | bSIE_FIFO_OF   | RW     | 1: Enable the corresponding interrupt;  | 0              |
|         |                |        | 0: Disable the corresponding interrupt. |                |
|         |                |        | Single block completion interrupt:      |                |
| 7       | bSIE_BLOCK_GAP | RW     | 1: Enable the corresponding interrupt;  | 0              |
|         |                |        | 0: Disable the corresponding interrupt. |                |
|         |                |        | Request block transmission completion   |                |
| 6       | bSIE TRANS SC  | RW     | interrupt:                              | 0              |
| Ū       |                |        | 1: Enable the corresponding interrupt;  | Ū              |
|         |                |        | 0: Disable the corresponding interrupt. |                |
|         |                |        | Block transmission CRC error interrupt: |                |
| 5       | bSIE_TRANS_ER  | RW     | 1: Enable the corresponding interrupt;  | 0              |
|         |                |        | 0: Disable the corresponding interrupt. |                |
| 4       | bSIE_DATA_TMO  | RW     | Data timeout interrupt:                 | 0              |
|         |                | 1      | 1: Enable the corresponding interrupt;  | 0              |

|   |                |    | 0: Disable the corresponding interrupt. |   |
|---|----------------|----|-----------------------------------------|---|
|   |                |    | Command completion interrupt:           |   |
| 3 | bSIE_CMD_DONE  | RW | 1: Enable the corresponding interrupt;  | 0 |
|   |                |    | 0: Disable the corresponding interrupt. |   |
|   |                |    | Response index check error interrupt:   |   |
| 2 | bSIE_RE_IDX_ER | RW | 1: Enable the corresponding interrupt;  | 0 |
|   |                |    | 0: Disable the corresponding interrupt. |   |
|   |                |    | Response CRC check error interrupt:     |   |
| 1 | bSIE_RE_CRC_WR | RW | 1: Enable the corresponding interrupt;  | 0 |
|   |                |    | 0: Disable the corresponding interrupt. |   |
|   |                |    | Command response timeout interrupt:     |   |
| 0 | bSIE_RE_TMOUT  | RW | 1: Enable the corresponding interrupt;  | 0 |
|   |                |    | 0: Disable the corresponding interrupt. |   |

#### Data block DMA start address register (SDx DMA) (x=0/1/2/3)

| Bit    | Name   | Access | Description                                                                                     | Reset<br>value |
|--------|--------|--------|-------------------------------------------------------------------------------------------------|----------------|
| [15:0] | SD_DMA | RW     | Start address of read/write data buffer, the lower 3 bits are fixed to 0 (8 bytes are aligned). | 0000h          |

Note: When reading data from SD, this register stores the read data in the start address of SRAM. When writing data to SD card, the data to be written is stored in the start address of SRAM.

If continuous multi-block read/write SD operations are performed, the user can write to the SDx\_DMA register to change the DMA address as needed after the single block transmission is completed (bSIF BLOCK GAP).

When performing continuous multi-block writing, it is required to start the continued write operation by writing to the SDx\_WRITE\_CONT or SDx\_DMA register after the single block transmission is completed. It is not required for multi-block read operation.

| Bit     | Name       | Access | Description                                                                                                                                                                   | Reset<br>value |
|---------|------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| [31:28] | Reserved   | RO     | Reserved.                                                                                                                                                                     | 0              |
| [27:16] | BLOCK_SIZE | RW     | Single block transmission size (1-2048 bytes).                                                                                                                                | 0              |
| [15:0]  | BLOCK_NUM  | RW     | Count of blocks (1~65535 blocks) to be transmitted by DMA this time, automatically cleared internally. If the number of blocks is not zero, enable receiving or transmitting. | 0              |

### Transmission block configuration register (SDx\_BLOCK\_CFG) (x=0/1/2/3)

## Transmission mode register (SDx\_TRAN\_MODE) (x=0/1/2/3)

| Bit   | Name          | Access | Description                                                                                           | Reset<br>value |
|-------|---------------|--------|-------------------------------------------------------------------------------------------------------|----------------|
| [7:3] | Reserved      | RO     | Reserved.                                                                                             | 0              |
| 2     | bTM_EMMC_BOOT | RW     | Set the eMMC card transmission mode:<br>1: Boot mode;<br>0: Normal mode.<br>Note: Only for eMMC card. | 0              |
| 1     | Reserved      | RO     | RO Reserved.                                                                                          |                |
| 0     | bTM_WR_SD     | RW     | Direction of DMA transmission:<br>1: From controller to SD;                                           | 0              |

0: From SD to controller.

## **12.3 SD Control Application**

#### **12.3.1 SD Command Transmit Operation:**

1. Set the 32-bit SDx\_ARGUMENT parameter register;

2. Set the 16-bit SDx\_CMD\_SET register;

3. Wait for the command transmit status, and query the SDx\_INT\_FG register. If the command is sent successfully, it will generate the command transmission success flag. Otherwise, it will generate CRC error, or timeout, or respond index error flag.

#### 12.3.2 Operation of Reading SD Card multi-Block Data:

1. Set the SDx\_DMA register, set SD0x\_TRAN\_MODE register to configure DMA transmission direction from SD to controller, set SD\_BLOCK\_CFG (the number of bytes received per block, and the number of blocks to be received by DMA), and the controller is now ready to start receiving the data blocks returned by the SD card.

2. Set the 32-bit SDx\_ARGUMENT parameter register and SDx\_CMD\_SET register, to send CMD18 (command of reading multiple blocks).

3. Wait for the command to be sent.

4. After the controller has successfully received N blocks, transmission success interrupt may be generated (bSIF\_TRANS\_SC=1). If a transmission error occurs in the middle, a corresponding error interrupt will be generated. At this time, read the status register (SDx\_STATUS) to know the number of blocks that have been successfully transmitted this time.

#### **12.3.3 Operation of Writing SD Card multi-Block Data:**

1. Set the 32-bit SDx\_ARGUMENT parameter register and SDx\_CMD\_SET register, to send CMD25 (command of writing multiple blocks).

2. Wait for the command to be sent.

1. Set the SDx\_DMA register, set SDx\_TRAN\_MODE register to configure the DMA transmission direction from controller to SD, set SDx\_BLOCK\_CFG (the number of bytes sent per block, and the number of blocks to be sent by the DMA), and the controller now starts to send the data block to SD card.

4. After the controller has successfully sent N blocks, transmission success interrupt may be generated (bSIF\_TRANS\_SC=1). If a transmission error occurs in the middle, a transmission error interrupt will be generated. At this time, read the status register (SDx\_STATUS) to know the number of blocks that have been successfully transmitted this time.

## 12.4 AES/SM4 Module Function Description

CH567 is equipped with a built-in block cipher algorithm module, which supports two types of block cipher algorithms (AES and SM4), and electronic codebook (ECB) and counter (CTR) modes. There are totally 8 combinations as follows:

ECB mode and CTR mode with SM4 algorithm 128bit key; ECB mode and CTR mode with AES algorithm 128bit key; ECB mode and CTR mode with AES algorithm 192bit key; ECB mode and CTR mode with AES algorithm 256bit key;

#### 12.4.1 AES/SM4 Algorithm

The AES (Advanced Encryption Standard) algorithm is a block encryption method that uses a symmetric block cipher system, which is one of the most popular algorithms in symmetric key encryption. The SM4 block cipher algorithm is generally a special block cipher algorithm for wireless local area

networks and trusted computers, and it can also be used for data encryption protection in other environments.

In the process of data encryption and decryption, the key needs to be loaded. For the AES algorithm, the user key is extended to  $11 \times 128/13 \times 128/15 \times 128$ -bit extended keys by setting the key length to 128/192/256 bits. While for SM4 algorithm, the 128-bit user key is extended to  $32 \times 32$ -bit extended key. These extended keys are stored in internal registers for use during encryption and decryption.

#### 12.4.2 ECB and CTR Mode

AES/SM4 supports two modes, including electronic codebook (ECB) mode and counter (CTR) mode. Among them, the security performance of CTR mode is higher than that of ECB mode. The difference between the two is shown in Figure 13-1. In ECB mode, there is a one-to-one correspondence between plain text and cipher text, and the encrypted plain text is directly used as cipher text. While in CTR mode, a 128-bit counter value needs to be loaded in advance to encrypt the count value, and the encrypted count value is different from the plain text or used as the cipher text. It is worth noting that in CTR decryption mode, only the count value is encrypted, but not decrypted.



(a) Encryption in ECB mode

(b) Decryption in ECB mode



(c) Encryption in CTR mode

(d) Decryption in CTR mode

Figure 12-1 Encryption and Decryption Diagrams in ECB and CTR Modes

## 12.5 AES/SM4 Module Register Description

AES/SM4 module related register physical base address: 0x0040 c400

| i. |              |                | 6                        |             |
|----|--------------|----------------|--------------------------|-------------|
|    | Name         | Offset address | Description              | Reset value |
|    | AES_SM4_CTRL | 0x00           | AES/SM4 control register | 32h20       |

| i              |      |                                 | 1          |
|----------------|------|---------------------------------|------------|
| AES_SM4_INT_FG | 0x04 | AES/SM4 interrupt flag register | 32h0       |
| AES_SM4_KEY7   | 0x08 | Key register 7                  | 32hxxxxxxx |
| AES_SM4_KEY6   | 0x0C | Key register 6                  | 32hxxxxxxx |
| AES_SM4_KEY5   | 0x10 | Key register 5                  | 32hxxxxxxx |
| AES_SM4_KEY4   | 0x14 | Key register 4                  | 32hxxxxxxx |
| AES_SM4_KEY3   | 0x18 | Key register 3                  | 32hxxxxxxx |
| AES_SM4_KEY2   | 0x1C | Key register 2                  | 32hxxxxxxx |
| AES_SM4_KEY1   | 0x20 | Key register 1                  | 32hxxxxxxx |
| AES_SM4_KEY0   | 0x24 | Key register 0                  | 32hxxxxxxx |
| AES_SM4_IV3    | 0x28 | Count value register 3          | 32hxxxxxxx |
| AES_SM4_IV2    | 0x2C | Count value register 2          | 32hxxxxxxx |
| AES_SM4_IV1    | 0x30 | Count value register 1          | 32hxxxxxxx |
| AES_SM4_IV0    | 0x34 | Count value register 0          | 32hxxxxxxx |

# AES/SM4 control register (AES\_SM4\_CTRL)

| Bit     | Name            | Access | Description                                | Reset<br>value |  |
|---------|-----------------|--------|--------------------------------------------|----------------|--|
| [31:17] | Reserved        | RO     | Reserved.                                  | 0              |  |
|         |                 |        | Key expansion completion interrupt enable: |                |  |
| 16      | bKEYE_ACT_IE    | RW     | 1: Enable the corresponding interrupt;     | 0              |  |
|         |                 |        | 0: Disable the corresponding interrupt.    |                |  |
| [15:12] | Reserved        | RO     | Reserved.                                  | 0              |  |
|         |                 |        | Key length setting:                        |                |  |
|         |                 |        | 00:128-bit;                                |                |  |
| [11:10] | MASK_Key_LEN    | RW     | 01:192-bit;                                | 0              |  |
|         |                 |        | 10:256-bit;                                |                |  |
|         |                 |        | 11: Reserved.                              |                |  |
|         |                 |        | Block cipher mode selection bit:           |                |  |
| 9       | bBCIPHER_MOD    | RW     | 1: CTR mode;                               | 0              |  |
|         |                 |        | 0: ECB mode.                               |                |  |
|         |                 |        | Algorithm mode selection bit:              |                |  |
| 8       | bALGRM_MOD      | RW     | 1:AES;                                     | 0              |  |
|         |                 |        | 0:SM4.                                     |                |  |
| [7:6]   | Reserved        | RO     | Reserved.                                  | 0              |  |
|         |                 |        | Encryption and decryption module clock     |                |  |
|         |                 |        | frequency division factor,                 |                |  |
| [5:4]   | MASV ED CLV DDE | RW     | Calculation: EDclk=480M/ED_CLK_PRE.        | 10b            |  |
| [3:4]   | MASK_ED_CLK_PRE | κw     | The minimum value is 2, and writing 1 is   | 100            |  |
|         |                 |        | equivalent to turning off ECDC module      |                |  |
|         |                 |        | operation clock.                           |                |  |
| 3       | LEDMOD SELT     | RW     | 1: Decryption mode;                        | 0              |  |
| 3       | bEDMOD_SELT     | ĸw     | 0: Encryption mode.                        | U              |  |
|         |                 |        | Enable to write SD data for encryption and |                |  |
| 2       | LADDAT ED EN    | RW     | decryption control bit:                    | 0              |  |
| 2       | bRDDAT_ED_EN    | ΓW     | 1: Encryption and decryption;              | 0              |  |
|         |                 |        | 0: No action.                              |                |  |
| 1       | WDDAT ED EN     | RW     | Enable to read SD data for encryption and  | 0              |  |
| 1       | bWRDAT_ED_EN    | πw     | decryption control bit:                    | 0              |  |

|   |          |    | 1: Encryption and decryption;<br>0: No action.                      |   |
|---|----------|----|---------------------------------------------------------------------|---|
| 0 | bKEYE_EN | RW | Key extension function enable control bit, high level pulse enable. | 0 |

Note: When the bKEYE\_EN bit is used, it needs to be set high and then low.

#### AES/SM4 interrupt flag register (AES SM4 INT FG)

| Bit     | Name         | Access | Description         Reset<br>value                                                                                                                            |   |
|---------|--------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| [31:17] | Reserved     | RO     | Reserved.                                                                                                                                                     | 0 |
| 16      | bKEYE_ACT_IF | RW1    | <ul><li>Key extension completion interrupt flag bit,</li><li>write 1 to clear it:</li><li>1: Key expansion completion trigger;</li><li>0: No event.</li></ul> | 0 |
| [15:0]  | Reserved     | RO     | Reserved.                                                                                                                                                     | 0 |

## User key register group (AES\_SM4\_KEYn) (n=0-7)

| Bit    | Name         | Access | Description               | Reset<br>value |
|--------|--------------|--------|---------------------------|----------------|
| [31:0] | AES_SM4_KEY7 | RW     | User key 223-256 bits.    | Х              |
| [31:0] | AES_SM4_KEY6 | RW     | User key 192-223 bits.    | Х              |
| [31:0] | AES_SM4_KEY5 | RW     | RW User key 160-191 bits. |                |
| [31:0] | AES_SM4_KEY4 | RW     | User key 128-159 bits.    | Х              |
| [31:0] | AES_SM4_KEY3 | RW     | User key 96-127 bits.     | Х              |
| [31:0] | AES_SM4_KEY2 | RW     | User key 64-95 bits.      | Х              |
| [31:0] | AES_SM4_KEY1 | RW     | User key 32-63 bits.      | Х              |
| [31:0] | AES_SM4_KEY0 | RW     | User key 0-31 bits.       | Х              |

#### Count value register group (AES\_SM4\_IVn) (n=0-3)

| Bit    | Name        | Access | Description                 | Reset<br>value |
|--------|-------------|--------|-----------------------------|----------------|
| [31:0] | AES_SM4_IV3 | RW     | Count value of 96-127 bits. | Х              |
| [31:0] | AES_SM4_IV2 | RW     | Count value of 64-95 bits.  | Х              |
| [31:0] | AES_SM4_IV1 | RW     | Count value of 32-63 bits.  | Х              |
| [31:0] | AES_SM4_IV0 | RW     | Count value of 0-31 bits.   | Х              |

## 12.6 Data Storage Encryption and Decryption Applications

## 12.6.1 Data Encryption Function Configuration

1. Set AES/SM4 control register AES\_SM4\_CTRL: set bCLR\_ALL\_IF bit to 1, clear interrupt, select AES or SM4 algorithm, select ECB or CTR mode, and set key length. Note that SM4 algorithm only supports 128-bit key length;

2. Set user key register group and fill in the key. If ETC mode is used, it is also required to set the group value of count value register;

3. Set the bKEYE\_EN of control register AES\_SM4\_CTRL, set it to 1 and then to 0, to enable the key expansion;

4. Query the interrupt flag register AES\_SM4\_INT\_FG and wait for the key extension to complete the interrupt. Optionally, turn on the key expansion completion interrupt enable bit bKEYE\_ACT\_IE of control

register and wait for the interrupt to be triggered;

5. Clear the interrupt. Set the bEDMOD\_SELT bit of the control register to 0, select the encryption mode, and set the bRDDAT\_ED\_EN bit to 1, to enable the encryption function when transmitting data from SRAM to SD, or set the bWRDAT\_ED\_EN bit to 1, to enable the encryption function when transmitting data from SD to SRAM.

#### 12.6.2 Data Decryption Function Configuration

1. Set AES/SM4 control register AES\_SM4\_CTRL: set bCLR\_ALL\_IF bit to 1, clear interrupt, select AES or SM4 algorithm, select ECB or CTR mode, and set key length. Note that SM4 algorithm only supports 128-bit key length;

2. Set user key register group and fill in the key. If CTR mode is used, it is also required to set the group value of count value register;

3. Set the bKEYE\_EN of control register AES\_SM4\_CTRL, set it to 1 and then to 0, to enable the key expansion;

4. Query the interrupt flag register AES\_SM4\_INT\_FG and wait for the key extension to complete the interrupt. Optionally, turn on the key expansion completion interrupt enable bit bKEYE\_ACT\_IE of control register and wait for the interrupt to be triggered;

5. Clear the interrupt. Set the bEDMOD\_SELT bit of the control register to 1, select the decryption mode, and set the bRDDAT\_ED\_EN bit to 1, to enable the encryption function when transmitting data from SRAM to SD, or set the bWRDAT\_ED\_EN bit to 1, to enable the decryption function when transmitting data from SD to SRAM.

# **Chapter 13 External Bus Interface (PARA)**

# **13.1 Introduction to External Bus Interface**

CH567 chip is equipped with an external bus controller that supports 8-bit bus width and address space ranges from 0x00800000 to 00807FFF, including read signal pin (PRD#), write signal pin (PWR#), 15-bit address pin (PA0-PA14) and 8-bit data pin (PB0-PB7). When the bus interface is not used, the above pins can be used as general purpose I/O ports. The interface supports static memory mapping components, including RAM, ROM, Flash, and some external I/O components, and it can automatically modify the pulse width of read/write signals as well as the creat and hold time of address and data.

External bus interface features:

(1). Support 8-bit bus width;

(2). Support up to 15-bit address bus width;

(3). Support static memory mapping components, including RAM, Flash and some external I/O components;

(4). Support dynamically modify pulse width, address and data setup and hold time of read/write signals, etc.;

# **13.2 Register Description**

External bus interface related register physical start address: 0x0040 1000

Table 9-1 List of External Bus Interface Related Registers

| Name           | Offset address | Description                         | Reset value |
|----------------|----------------|-------------------------------------|-------------|
| R8_XBUS_CONFIG | 0x10           | External bus configuration register | 8h00        |

| Bit   | Name                                                                                            | Access              | Description                         | Reset<br>value |
|-------|-------------------------------------------------------------------------------------------------|---------------------|-------------------------------------|----------------|
|       |                                                                                                 |                     | External bus data setup time:       |                |
| 7     | RB_XBUS_SETUP                                                                                   | RW                  | 1: 3 clock cycles;                  | 0              |
|       |                                                                                                 |                     | 0: 2 clock cycles.                  |                |
|       |                                                                                                 |                     | External bus data hold time:        |                |
| 6     | RB_XBUS_HOLD                                                                                    | RW                  | 1: 3 clock cycles;                  | 0              |
|       |                                                                                                 |                     | 0: 2 clock cycles.                  |                |
|       |                                                                                                 |                     | External bus RD/WR valid time:      |                |
|       |                                                                                                 |                     | 00: 3 clock cycles;                 |                |
| [5:4] | RB_XBUS_WIDTH     RW     01: 5 clock cycles;       10: 9 clock cycles;     11: 16 clock cycles. | 0                   |                                     |                |
|       |                                                                                                 | 10: 9 clock cycles; |                                     |                |
|       |                                                                                                 |                     | 11: 16 clock cycles.                |                |
|       |                                                                                                 |                     | External bus address output enable: |                |
|       |                                                                                                 |                     | 00: No bus address output;          |                |
| [3:2] | RB_XBUS_ADDR_OE                                                                                 | RW                  | 01: Address line PA[5:0];           | 0              |
|       |                                                                                                 |                     | 10: Address line PA[9:0];           |                |
|       |                                                                                                 |                     | 11: Address line PA[14:0].          |                |
| 1     | Resered                                                                                         | RO                  | Reserved.                           | 0              |
| 0     | RB XBUS ENABLE                                                                                  | RW                  | External bus enable bit:            | 0              |
| U     | KD_ADUS_ENADLE                                                                                  | IX VV               | 1: Enable;                          | U              |

External bus configuration register (R8 XBUS CONFIG)

0: Disable.

## **13.3 External Bus Interface Application**

#### **13.3.1 External Bus Interface**

The external bus interface includes 1 read signal pin PRD# (PB8), 1 write signal pin PWR# (PB9), 15 address pins A0-A14 (PA0-PA14) and 8 data pins D0-D7 (PB0-PB7). The interface supports 8-bit data bus width.

8-bit wide memory interface:



Figure 9-1 8-bit Bus Interface Connected to 8-bit Memory Chip

#### 13.3.2 Typical Bus Timing

The following figure shows a typical external bus interface read/write access timing, Fsys is the bus clock frequency, RD is the read signal pin, and WR is the write signal pin.

For example, after setting RB\_XBUS\_WIDTH = 01b, RB\_XBUS\_HOLD = 0b, RB\_XBUS\_SETUP = 0b, the timing diagram is as follows:



Figure 9-2 External Line Interface Read/Write Access Timing Diagram

The RB\_XBUS\_SETUP bit in the figure above is the data setup time. When it is set to 0, the external bus setup time is 2 clock cycles (Tsys). When it is set to 1, the external bus setup time is 3 clock cycles (Tsys). The RB\_XBUS\_HOLD bit is data hold time. When it is set to 0, the data hold time is 2 clock cycles (Tsys). When it is set to 1, the data hold time is 3 clock cycles (Tsys). When it is set to 1, the data hold time is 3 clock cycles (Tsys). RB\_XBUS\_WIDTH is the effective pulse width of bus data read and write, and 3 clocks, 5 clocks, 9 clocks or 16 clocks are optional.

#### **13.3.3 External Bus Configuration**

The main configuration steps are shown below:

(1). Configure the external bus configuration register (R8\_XBUS\_CONFIG), set the RB\_XBUS\_ENABLE bit to 1 to enable the external bus interface, and set the address bit control domain RB XBUS ADDR OE as needed, to select the required addressing range;

(2). Configure the external bus configuration register (R8\_XBUS\_CONFIG), set the RB\_XBUS\_WIDTH bit control domain, to select the bus read/write clock pulse width, set the RB\_XBUS\_SETUP bit and RB\_XBUS\_HOLD bit, to select the bus setup time and bus hold time;

(3) Configure the corresponding pin direction of external bus interface.

The main configuration programs are shown below:

/\* Configure external bus interface related registers, enable parallel port bus function, 15 address lines, bus read/write clock pulse width 5 clocks, bus setup time and hold time of 2 clocks each \*/

 $R8\_XBUS\_CONFIG = 0x1d;$ 

/\* Configure the corresponding pins of the external bus interface \*/

R32 PA DIR  $\models$  0x7FFF; // Can only use part of the address pins

 $R32_PB_DIR \models (PWR \mid PRD);$ 

# **Chapter 14 Interrupt**

## 14.1 Interrupt Controller

CH567 chip supports multiple interrupt sources, with a total of 16 peripheral interrupt sources, including UART, SPI, TMR, USB, GPIO, etc.

| Default priority order | Interrupt No. | Priority            | Name  | Description                                |
|------------------------|---------------|---------------------|-------|--------------------------------------------|
|                        | 0             | Level 2, can be set | SOFT  | Software interrupt                         |
| High priority          | 1             | Level 2, can be set | TMR0  | Timer0 interrupt                           |
|                        | 2             | Level 2, can be set | GPIO  | GPIO port interrupt                        |
| ¥<br>                  | 3             | Level 2, can be set | SPI0  | SPI0 interrupt                             |
| ↓<br>↓                 | 4             | Level 2, can be set | USB0  | USB0 interrupt                             |
| Ļ                      | 5             | Level 2, can be set | TMR1  | Timer1 interrupt                           |
| $\downarrow$           | 6             | Level 2, can be set | TMR2  | Timer2 interrupt                           |
| $\downarrow$           | 7             | Level 2, can be set | UART0 | UART0 interrupt                            |
| $\downarrow$           | 8             | Level 2, can be set | USB1  | USB1 interrupt                             |
| $\downarrow$           | 9             | Level 2, can be set | SDC   | SD controller interrupt                    |
| $\downarrow$           | 10            | Level 2, can be set | ECDC  | Encryption/decryption controller interrupt |
| $\downarrow$           | 11            | Level 2, can be set | LED   | LED controller interrupt                   |
| $\downarrow$           | 12            | Level 2, can be set | SPI1  | SPI1 interrupt                             |
| ↓                      | 13            | Level 2, can be set | UART1 | UART1 interrupt                            |
| Low priority           | 14            | Level 2, can be set | UART2 | UART2 interrupt                            |
|                        | 15            | Level 2, can be set | UART3 | UART3 interrupt                            |

Table 14-1 Interrupt Vector

## **14.2 Interrupt Instruction**

1) To use the interrupt function of CH567 chip, you need to add the following functions to the software code to enable the system interrupt control.

void Interrupt\_init(void);

2) Enable the corresponding interrupt control bit of interrupt enable register of corresponding peripheral module, to trigger the interrupt under the corresponding trigger condition.

3) Refer to the following example to write interrupt function. Taking TMR0 as example, the interrupt number is 1:

```
__attribute__((interrupt("id=1")))void TIME0_Deal()
{
    static UINT16 j=0;
    if(R8_TMR0_INT_FLAG & RB_TMR_IF_CYC_END)
    {
        j++;
        if(j>300){
            printf("*\n");
            j = 0;
        }
        R8_TMR0_INT_FLAG |= RB_TMR_IF_CYC_END; //Clear flag
    }
}
```

# **Chapter 15 Parameters**

# **15.1 Absolute Maximum Value**

Critical value or exceeding the absolute maximum value may cause the chip to work abnormally or even be damaged.

| Table 15-1 Absolute Maximum Value Parameters |
|----------------------------------------------|
|----------------------------------------------|

| Name   | Parameter des                                             | scription                                     | Min.       | Max.       | Unit |
|--------|-----------------------------------------------------------|-----------------------------------------------|------------|------------|------|
| TA     | Ambient temperature during operation                      | V33REG=3.3V<br>V33USB=3.3V<br>V33IO1/2/3=3.3V | -40        | 85         | °C   |
| TS     | Ambient temperature                                       | during storage                                | -55        | 125        | °C   |
| V33REG | System supply voltage (V33<br>supply, GND to              |                                               | -0.4       | 4.2        | V    |
| V33USB | USB0 supply voltage (V33U supply, GND to                  | -0.4                                          | 4.2        | V          |      |
| V33IO1 | Peripheral group 1 supply volt<br>power supply, GN        | -0.4                                          | 4.2        | V          |      |
| V33IO2 | Peripheral group 2 supply volt<br>power supply, GN        | -0.4                                          | 4.2        | V          |      |
| V33IO3 | Peripheral group 3 supply volta<br>power supply, GN       | -0.4                                          | 4.2        | V          |      |
| VIO0   | Voltage on input or output p<br>domain                    | -0.4                                          | V33USB+0.4 | V          |      |
| VIO1   | Voltage on input or output pins of V33IO1 power<br>domain |                                               | -0.4       | V33IO1+0.4 | V    |
| VIO2   | Voltage on input or output p<br>domain                    | -0.4                                          | V33IO2+0.4 | V          |      |
| VIO3   | Voltage on input or output p<br>domain                    |                                               | -0.4       | V33IO3+0.4 | V    |

# **15.2 Electrical Parameters**

Test conditions: TA=25°C, V33REG=3.3V, V33USB=3.3V, V33IO1/2/3=3.3V, Fsys=96MHz.

Table 15-2 Electrical Parameters

| Name   | Parameter description                                                                               | Min.    | Тур. | Max. | Unit      |    |
|--------|-----------------------------------------------------------------------------------------------------|---------|------|------|-----------|----|
| V33REG | System supply voltage                                                                               | V33REG  | 2.7  | 3.3  | 3.6       | V  |
| V33USB | USB0 supply voltage                                                                                 | V33USB  | 3.0  | 3.3  | 3.6       | V  |
| V33IO1 | Peripheral group 1 supply voltage                                                                   | V33IO1  | 1.6  | 3.3  | 3.6       | V  |
| V33IO2 | Peripheral group 2 supply voltage V33IO2                                                            |         | 1.6  | 3.3  | 3.6       | V  |
| V33IO3 | Peripheral group 3 supply voltage V33IO3                                                            |         | 3.0  | 3.3  | 3.6       | V  |
| ICC    | Total supply current during operation                                                               |         | 20   | 55   | 150       | mA |
| ISLP   | Supply current when at low power status<br>(I/O pin output with no-load or input with<br>pull-down) |         | 240  | 270  | 350       | uA |
| VIL    | Low-level input voltage (V33IO=3.3V)                                                                |         | -0.4 | -    | 0.7       | V  |
| VIH    | High-level input voltage (V33I                                                                      | O=3.3V) | 2.0  | -    | V33IO+0.4 | V  |

| VIL18 | Low-level input voltage (V33IO1/2=1.8V)                              | -0.4 | -   | 0.5       | V  |
|-------|----------------------------------------------------------------------|------|-----|-----------|----|
| VIH18 | High-level input voltage (V33IO1/2=1.8V)                             | 1.2  | -   | V33IO+0.4 | V  |
| VOL   | Low level output voltage (6mA draw current)                          | -    | -   | 0.4       | V  |
| VOH   | High level output voltage (5mA output current)                       |      | -   | -         | V  |
| IUP   | Input current at the input terminal with built-in pull-up resistor   | 25   | 45  | 80        | uA |
| IDN   | Input current at the input terminal with built-in pull-down resistor | -25  | -45 | -80       | uA |
| Vpot  | Voltage threshold for VCORE core power<br>supply power-on reset      | 0.6  | 0.7 | 0.8       | V  |

# **15.3 Static Current of Function Module**

Test conditions: TA=25°C, V33REG=3.3V, V33USB=3.3V, V33IO1/2/3=3.3V.

| Table 15-3 Dy | namic curren | t of Functi | on Module |  |
|---------------|--------------|-------------|-----------|--|
|               |              |             |           |  |

| Frequency<br>Function Module | 30M   | 60M   | 96M   | 120M  | Unit |
|------------------------------|-------|-------|-------|-------|------|
| USB0/USB1                    | 0.2   | 0.4   | 0.65  | 0.79  | mA   |
| USB0-Phy                     |       | 1     | 0     |       | mA   |
| USB1-Phy                     |       | 1     | 5     |       | mA   |
| SDC-96MHz                    | 12.45 | 13.53 | 14.84 | 15.65 | mA   |
| SDC-48MHz                    | 6.28  | 7.39  | 8.64  | 9.49  | mA   |
| SDC-24MHz                    | 4.16  | 5.22  | 6.5   | 7.32  | mA   |
| ECDC-240MHz                  | 15.64 | 16.88 | 17.72 | 19.3  | mA   |
| ECDC-160MHz                  | 10.99 | 12.25 | 13.79 | 14.69 | mA   |
| TMR+UART+SPI+PWM             | 0.17  | 0.33  | 0.51  | 0.7   | mA   |
| PLL                          | 7     |       | mA    |       |      |
| Core+BUS+DMA                 | 24    | 27    | 31    | 34    | mA   |

# **15.4 Timing Parameters**

Test conditions: TA=25°C, V33REG=3.3V, V33USB=3.3V, V33IO1/2/3=3.3V, Fsys=96MHz.

Table 15-4 Timing Parameters

|      | 8                                                           |      |        |      |      |
|------|-------------------------------------------------------------|------|--------|------|------|
| Name | Parameter description                                       | Min. | Тур.   | Max. | Unit |
| Trst | Effective signal width of external reset input RST#         | 50   | 2*Tsys | -    | ns   |
| Tpro | Reset delay after power-on reset                            | 22   | 32     | 50   | mS   |
| Tsro | Reset delay after external/software reset input + load time | 8    | 8.8    | 10   | mS   |
| TWAK | Wake-up time to exit from low-power state                   | 0.2  | 1      | 5    | mS   |

# **Chapter 16 Package**

Chip package

| Package | Width Of<br>Plastic | Pitch Of Pin |         | Instruction Of Package    | Ordering<br>Information |
|---------|---------------------|--------------|---------|---------------------------|-------------------------|
| LQFP-48 | 7*7mm               | 0.5mm        | 19.7mil | Standard LQFP48 pin patch | CH567L                  |

Remarks :

The unit of dimension is mm (millimeters)

The pin center spacing is the nominal value, there is no error, and the other dimension error is not greater than  $\pm 0.5$ mm.



# **Chapter 17 Modification Record**

| Version | Date             | Description                          |  |  |
|---------|------------------|--------------------------------------|--|--|
| V1.0    | May 10, 2017     | First release                        |  |  |
| V1.1    | October 29, 2018 | Some error descriptions are modified |  |  |